CN104765646A - 组件调用方法及装置 - Google Patents

组件调用方法及装置 Download PDF

Info

Publication number
CN104765646A
CN104765646A CN201510118066.5A CN201510118066A CN104765646A CN 104765646 A CN104765646 A CN 104765646A CN 201510118066 A CN201510118066 A CN 201510118066A CN 104765646 A CN104765646 A CN 104765646A
Authority
CN
China
Prior art keywords
assembly
application
data directory
call
data
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
CN201510118066.5A
Other languages
English (en)
Other versions
CN104765646B (zh
Inventor
江波
蒋黎峰
谢哲
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Beijing Xiaomi Technology Co Ltd
Xiaomi Inc
Original Assignee
Xiaomi Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Xiaomi Inc filed Critical Xiaomi Inc
Priority to CN201510118066.5A priority Critical patent/CN104765646B/zh
Publication of CN104765646A publication Critical patent/CN104765646A/zh
Application granted granted Critical
Publication of CN104765646B publication Critical patent/CN104765646B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Landscapes

  • Stored Programmes (AREA)

Abstract

本公开是关于一种组件调用方法及装置,属于计算机技术领域。所述方法包括:根据第一应用的调用需求,在第二应用的数据目录中,确定第一组件;对第一组件进行包装,得到第二组件;在第一应用的运行过程中,当检测到对第二组件的调用指令时,在运行第一应用的进程中,运行第二组件。本发明通过在第二应用的数据目录中,确定第一组件,对第一组件进行包装,得到第二组件,在第一应用的运行过程中,当检测到对第二组件的调用指令时,在运行第一应用的进程中,运行第二组件。由于调用的第二组件运行在第一应用的进程中,第一应用的进程仍处于前台,能避免应用进程因处于后台而被终止的可能性,从而提高了系统运行时的稳定性。

Description

组件调用方法及装置
技术领域
本公开涉及计算机技术领域,特别涉及一种组件调用方法及装置。
背景技术
随着计算机技术的发展,终端上能够使用的应用程序越来越多。应用程序通常由一些有联系的组件组成,为了实现不同的功能,一些应用可能需要调用其它应用下的组件。目前组件调用方法主要是:当第一应用需要调用第二应用下的组件时,系统启动第二应用,将第二应用置为前台应用,将第一应用置为后台应用,并调用第二应用下的组件。
发明内容
为克服相关技术中存在的问题,本公开提供了一种组件调用方法及装置。
根据本公开实施例的第一方面,提供了一种组件调用方法,该方法包括:
根据第一应用的调用需求,在第二应用的数据目录中,确定第一组件,所述第一组件为所述第一应用在运行过程中被调用的组件;
对所述第一组件进行包装,得到第二组件,所述第二组件的进程配置信息为所述第一应用的包名;
在所述第一应用的运行过程中,当检测到对所述第二组件的调用指令时,在运行所述第一应用的进程中,运行所述第二组件。
结合第一方面,在第一方面的第一种可能的实现方式中,所述根据第一应用的调用需求,在第二应用的数据目录中,确定第一组件,包括:
根据第一应用的调用需求,确定第二应用的包名及第一组件名;
根据所述第二应用的包名与数据目录的对应关系,确定所述第二应用的数据目录;
根据所述第一组件名,在所述第二应用的数据目录下进行查找,找到对应的第一组件。
结合第一方面,在第一方面的第二种可能的实现方式中,所述根据第一应用的调用需求,在第二应用的数据目录中,确定第一组件之前,还包括:
将第一应用与第二应用下的数据设置为互相可见。
结合第一方面的第二种可能的实现方式,在第一方面的第三种可能的实现方式中,所述将第一应用与第二应用下的数据设置为互相可见,包括:
将所述第一应用与所述第二应用设置为相同的分享标识;
通过相同的证书为所述第一应用及所述第二应用进行签名。
结合第一方面,在第一方面的第四种可能的实现方式中,所述对所述第一组件进行包装,得到第二组件,包括:
创建所述第一组件的包装类,将所述包装类作为第二组件;
或者,创建所述第一组件的派生类,将所述派生类作为第二组件。
根据本公开实施例的第二方面,提供了一种组件调用装置,该装置包括:
确定模块,用于根据第一应用的调用需求,在第二应用的数据目录中,确定第一组件,所述第一组件为所述第一应用在运行过程中被调用的组件;
包装模块,用于对所述第一组件进行包装,得到第二组件,所述第二组件的进程配置信息为所述第一应用的包名;
运行模块,用于在所述第一应用的运行过程中,当检测到对所述第二组件的调用指令时,在运行所述第一应用的进程中,运行所述第二组件。
结合第二方面,在第二方面的第一种可能的实现方式中,所述确定模块,用于根据第一应用的调用需求,确定第二应用的包名及第一组件名;根据所述第二应用的包名与数据目录的对应关系,确定所述第二应用的数据目录;根据所述第一组件名,在所述第二应用的数据目录下进行查找,找到对应的第一组件。
结合第二方面,在第二方面的第二种可能的实现方式中,所述装置还包括:
设置模块,用于将第一应用与第二应用下的数据设置为互相可见。
结合第二方面的第二种可能的实现方式,在第二方面的第三种可能的实现方式中,所述设置模块,用于将所述第一应用与所述第二应用设置为相同的分享标识;通过相同的证书为所述第一应用及所述第二应用进行签名。
结合第二方面,在第二方面的第四种可能的实现方式中,所述包装模块,用于创建所述第一组件的包装类,将所述包装类作为第二组件;或者,创建所述第一组件的派生类,将所述派生类作为第二组件。
根据本公开实施例的第三方面,提供了一种终端,该终端包括:
处理器;
用于存储处理器可执行指令的存储器;
其中,所述处理器被配置为:
根据第一应用的调用需求,在第二应用的数据目录中,确定第一组件,所述第一组件为所述第一应用在运行过程中被调用的组件;
对所述第一组件进行包装,得到第二组件,所述第二组件的进程配置信息为所述第一应用的包名;
在所述第一应用的运行过程中,当检测到对所述第二组件的调用指令时,在运行所述第一应用的进程中,运行所述第二组件。
本公开实施例提供的技术方案带来的有益效果是:
通过在第二应用的数据目录中,确定第一组件,对第一组件进行包装,得到第二组件,在第一应用的运行过程中,当检测到对第二组件的调用指令时,在运行第一应用的进程中,运行第二组件。由于调用的第二组件运行在第一应用的进程中,第一应用的进程仍处于前台,能避免应用进程因处于后台而被终止的可能性,从而提高了系统运行时的稳定性。
应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本公开。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本发明的实施例,并与说明书一起用于解释本发明的原理。
图1是根据一示例性实施例示出的一种组件调用方法的流程图。
图2是根据一示例性实施例示出的一种组件调用方法的流程图。
图3是根据一示例性实施例示出的一种组件调用装置的示意图。
图4是根据一示例性实施例示出的一种组件调用装置的示意图。
图5是根据一示例性实施例示出的一种终端的框图。
具体实施方式
这里将详细地对示例性实施例进行说明,其示例表示在附图中。下面的描述涉及附图时,除非另有表示,不同附图中的相同数字表示相同或相似的要素。以下示例性实施例中所描述的实施方式并不代表与本发明相一致的所有实施方式。相反,它们仅是与如所附权利要求书中所详述的、本发明的一些方面相一致的装置和方法的例子。
图1是根据一示例性实施例示出的一种组件调用方法的流程图,该组件调用方法应用于终端。如图1所示,该组件调用方法包括以下步骤。
在本步骤101中,根据第一应用的调用需求,在第二应用的数据目录中,确定第一组件,第一组件为第一应用在运行过程中被调用的组件。
在本步骤102中,对第一组件进行包装,得到第二组件,第二组件的进程配置信息为第一应用的包名。
在本步骤103中,在第一应用的运行过程中,当检测到对第二组件的调用指令时,在运行第一应用的进程中,运行第二组件。
本公开实施例提供的方法,通过在第二应用的数据目录中,确定第一组件,对第一组件进行包装,得到第二组件,在第一应用的运行过程中,当检测到对第二组件的调用指令时,在运行第一应用的进程中,运行第二组件。由于调用的第二组件运行在第一应用的进程中,第一应用的进程仍处于前台,能避免应用进程因处于后台而被终止的可能性,从而提高了系统运行时的稳定性。
作为一种可选实施例,根据第一应用的调用需求,在第二应用的数据目录中,确定第一组件,包括:
根据第一应用的调用需求,确定第二应用的包名及第一组件名;
根据第二应用的包名与数据目录的对应关系,确定第二应用的数据目录;
根据第一组件名,在第二应用的数据目录下进行查找,找到对应的第一组件。
作为一种可选实施例,根据第一应用的调用需求,在第二应用的数据目录中,确定第一组件之前,还包括:
将第一应用与第二应用下的数据设置为互相可见。
作为一种可选实施例,将第一应用与第二应用下的数据设置为互相可见,包括:
将第一应用与第二应用设置为相同的分享标识;
通过相同的证书为第一应用及第二应用进行签名。
作为一种可选实施例,对第一组件进行包装,得到第二组件,包括:
创建第一组件的包装类,将包装类作为第二组件;
或者,创建第一组件的派生类,将派生类作为第二组件。
上述所有可选技术方案,可以采用任意结合形成本发明的可选实施例,在此不再一一赘述。
图2是根据一示例性实施例示出的一种组件调用方法流程图,如图2所示,该组件调用方法应用于终端中,包括以下步骤。
在步骤201中,根据第一应用的调用需求,确定第二应用的包名及第一组件名,第一组件为第一应用在运行过程中被调用的组件。
由于本实施例提供的方法是在运行一个应用时,调用另一个应用的组件,而不同应用之间通常有权限限制,不能互相访问双方的数据。因此,为了第一应用能够访问到第二应用的数据,在执行本步骤201之前,还可以将第一应用与第二应用下的数据设置为互相可见。
本实施例不对将第一应用与第二应用下的数据设置为互相可见的方式作具体限定,包括但不限于:将第一应用与第二应用设置为相同的分享标识;通过相同的证书为第一应用及第二应用进行签名。
例如,以第一应用与第二应用均为安卓Android中的应用为例。在Android系统中,每个应用都有一个分享标识ShareUserId。当应用之间拥有不同的ShareUserID时,则每个应用下的数据会被设置为只对该应用自身可见,其它应用不可见。因此,可将两个应用设置为相同的ShareUserID,从而两个应用下的数据能够互相可见。
另外,由于在通过上述方法实现数据共享时,两个应用需要通过相同的签名文件进行签名,即需通过相同的证书进行签名,否则应用安装时会失败,出现的错误为[INSTALL_FAILED_SHARED_USER_INCOMPATIBLE]。因此,可通过相同的证书为第一应用及第二应用进行签名。
在将第一应用与第二应用下的数据设置为互相可见后,可根据第一应用的调用需求,确定第二应用的包名及第一组件名。其中,第一应用的调用需求可为第一应用的执行逻辑,通过第一应用的执行逻辑,确定第一应用在执行过程需要实现的功能,从而确定实现该功能所需的第一组件名以及第一组件所从属的第二应用的包名。
例如,以第一应用为即使通讯应用为例。第一应用可能需要提供查询地图的功能,此时,第二应用可以为地图应用,从而可确定地图应用的包名及地图查询组件名。
在步骤202中,根据第二应用的包名与数据目录的对应关系,确定第二应用的数据目录。
其中,第二应用的数据目录可以为第二应用在终端上的安装文件夹,其中,数据目录用于存储该第二应用的安装相关数据,第二应用的数据目录可在第二应用包在终端上安装时生成,且第二应用的包名与数据目录的对应关系可在本地通过数据表的形式进行存储,本实施例对此不作具体限定。具体地,存储内容可如下表1所示:
表1
应用包名 数据目录
com.MIUI.mobileChat /sdcard/MIUI/mobilechat
com.MIUI.android.MIdownloader /sdcard/MIUI/MIassistant
例如,第二应用的包名为com.MIUI.mobileChat,则根据表1,确定第二应用的数据目录为/sdcard/MIUI/mobilechat。
在步骤203中,根据第一组件名,在第二应用的数据目录下进行查找,找到对应的第一组件。
由于第二应用的数据目录下存放有与第二应用相关的所有数据,而在上述步骤201中已确定第一组件名,从而可在第二应用的数据目录下,找到对应的第一组件。例如,若第一组件名为MapView,通过在第二应用的数据目录下进行查找,可以找到MapView组件的相关内容。
在步骤204中,对第一组件进行包装,得到第二组件,第二组件的进程配置信息为第一应用的包名。
由于在程序代码中,第一组件的形式通常为一个类。因此,在对第一组件进行包装时,可创建与第一组件相关的类。关于对第一组件进行包装,得到第二组件的方式,本实施例对此不作具体限定,包括但不限于:创建第一组件的包装类,将包装类作为第二组件;或者,创建第一组件的派生类,将派生类作为第二组件。
例如,以第二组件对应的类为MapView类为例,可创建一个MapView类的包装类WrapperMapView。或者,还可以创建一个MapView类的包装类DerivedMapView类。
另外,由于后续在运行第一应用的进程时,若需要调用第二组件,第二组件需要在第一应用的进程中运行。因此,为了实现上述目的,可对第二应用的manifest文件进行配置,本实施例对此不作具体限定。
其中,在manifest文件中,每种组件的manifest条目,都支持一个“android:process”的属性,通过该属性,可以指定某个组件运行的进程。通过为该属性指定应用包名,可让每个组件运行在它自身所属的进程中,也可以让某些组件共享一个进程。
基于上述原理,可将第二组件的进程配置信息,即第二组件的“android:process”的属性指定为第一应用的包名,从而后续能够在第一应用的进程中运行第二组件。
在步骤205中,在第一应用的运行过程中,当检测到对第二组件的调用指令时,在运行第一应用的进程中,运行第二组件。
通过上述步骤204,由于第二组件已具备了运行在第一应用的进程中的条件,从而当检测到对第二组件的调用指令时,可在第一应用的进程中运行第二组件。
另外,由于应用调用的是包装组件,通过在包装组件中添加统计函数,可很方便地统计不同应用对该包装组件的使用情况,如一段时间内对包装组件进行调用的调用次数等,本实施例对此不作具体限定。
需要说明的是,由于相关技术中第一应用在调用第二应用下的组件时,第一应用会被置为后台应用,第一应用在系统中的优先级会被降低。当系统内存等资源较紧张时,第一应用可能会因为系统资源不够而被杀掉,从而可能会造成系统异常,导致调用组件时系统的稳定性较低。本实施例提供的方法,通过让第二组件与第一应用运行在同一个进程中,从而避免了对应用进程进行切换。因此,系统的稳定性较高。
本公开实施例提供的方法,通过在第二应用的数据目录中,确定第一组件,对第一组件进行包装,得到第二组件,在第一应用的运行过程中,当检测到对第二组件的调用指令时,在运行第一应用的进程中,运行第二组件。由于调用的第二组件运行在第一应用的进程中,第一应用的进程仍处于前台,能避免应用进程因处于后台而被终止的可能性,从而提高了系统运行时的稳定性。
图3是根据一示例性实施例示出的一种组件调用装置的结构示意图,该装置用于执行上述图1或图2所对应的实施例中任一实施例所提供的组件调用方法,该组件调用装置应用于终端。参照图3,该装置包括确定模块301、包装模块302及运行模块303。
该确定模块301被配置为根据第一应用的调用需求,在第二应用的数据目录中,确定第一组件,第一组件为第一应用在运行过程中被调用的组件;
该包装模块302被配置为对第一组件进行包装,得到第二组件,第二组件的进程配置信息为第一应用的包名;
该运行模块303被配置为在第一应用的运行过程中,当检测到对第二组件的调用指令时,在运行第一应用的进程中,运行第二组件。
在一个实施例中,该确定模块301被配置为根据第一应用的调用需求,确定第二应用的包名及第一组件名;根据第二应用的包名与数据目录的对应关系,确定第二应用的数据目录;根据第一组件名,在第二应用的数据目录下进行查找,找到对应的第一组件。
在一个实施例中,参见图4,该装置还包括设置模块304。
该设置模块304被配置为将第一应用与第二应用下的数据设置为互相可见。
在一个实施例中,该设置模块304被配置为将第一应用与第二应用设置为相同的分享标识;通过相同的证书为第一应用及第二应用进行签名。
在一个实施例中,该包装模块302被配置为创建第一组件的包装类,将包装类作为第二组件;或者,创建第一组件的派生类,将派生类作为第二组件。
本公开实施例提供的装置,通过在第二应用的数据目录中,确定第一组件,对第一组件进行包装,得到第二组件,在第一应用的运行过程中,当检测到对第二组件的调用指令时,在运行第一应用的进程中,运行第二组件。由于调用的第二组件运行在第一应用的进程中,第一应用的进程仍处于前台,能避免应用进程因处于后台而被终止的可能性,从而提高了系统运行时的稳定性。
图5是根据一示例性实施例示出的一种终端500的框图。例如,终端500可以是移动电话,计算机,数字广播终端,消息收发设备,游戏控制台,平板设备,医疗设备,健身设备,个人数字助理等。
参照图5,终端500可以包括以下一个或多个组件:处理组件502,存储器504,电源组件506,多媒体组件508,音频组件510,输入/输出(I/O)的接口512,传感器组件514,以及通信组件516。
处理组件502通常控制终端500的整体操作,诸如与显示,电话呼叫,数据通信,相机操作和记录操作相关联的操作。处理元件502可以包括一个或多个处理器520来执行指令,以完成上述的方法的全部或部分步骤。此外,处理组件502可以包括一个或多个模块,便于处理组件502和其他组件之间的交互。例如,处理部件502可以包括多媒体模块,以方便多媒体组件508和处理组件502之间的交互。
存储器504被配置为存储各种类型的数据以支持在设备500的操作。这些数据的示例包括用于在终端500上操作的任何应用程序或方法的指令,联系人数据,电话簿数据,消息,图片,视频等。存储器504可以由任何类型的易失性或非易失性存储设备或者它们的组合实现,如静态随机存取存储器(SRAM),电可擦除可编程只读存储器(EEPROM),可擦除可编程只读存储器(EPROM),可编程只读存储器(PROM),只读存储器(ROM),磁存储器,快闪存储器,磁盘或光盘。
电力组件506为终端500的各种组件提供电力。电力组件506可以包括电源管理系统,一个或多个电源,及其他与为终端500生成、管理和分配电力相关联的组件。
多媒体组件508包括在所述终端500和用户之间的提供一个输出接口的屏幕。在一些实施例中,屏幕可以包括液晶显示器(LCD)和触摸面板(TP)。如果屏幕包括触摸面板,屏幕可以被实现为触摸屏,以接收来自用户的输入信号。触摸面板包括一个或多个触摸传感器以感测触摸、滑动和触摸面板上的手势。所述触摸传感器可以不仅感测触摸或滑动动作的边界,而且还检测与所述触摸或滑动操作相关的持续时间和压力。在一些实施例中,多媒体组件508包括一个前置摄像头和/或后置摄像头。当设备500处于操作模式,如拍摄模式或视频模式时,前置摄像头和/或后置摄像头可以接收外部的多媒体数据。每个前置摄像头和后置摄像头可以是一个固定的光学透镜系统或具有焦距和光学变焦能力。
音频组件510被配置为输出和/或输入音频信号。例如,音频组件510包括一个麦克风(MIC),当终端500处于操作模式,如呼叫模式、记录模式和语音识别模式时,麦克风被配置为接收外部音频信号。所接收的音频信号可以被进一步存储在存储器504或经由通信组件516发送。在一些实施例中,音频组件510还包括一个扬声器,用于输出音频信号。
I/O接口512为处理组件502和外围接口模块之间提供接口,上述外围接口模块可以是键盘,点击轮,按钮等。这些按钮可包括但不限于:主页按钮、音量按钮、启动按钮和锁定按钮。
传感器组件514包括一个或多个传感器,用于为终端500提供各个方面的状态评估。例如,传感器组件514可以检测到设备500的打开/关闭状态,组件的相对定位,例如所述组件为终端500的显示器和小键盘,传感器组件514还可以检测终端500或终端500一个组件的位置改变,用户与终端500接触的存在或不存在,终端500方位或加速/减速和终端500的温度变化。传感器组件514可以包括接近传感器,被配置用来在没有任何的物理接触时检测附近物体的存在。传感器组件514还可以包括光传感器,如CMOS或CCD图像传感器,用于在成像应用中使用。在一些实施例中,该传感器组件514还可以包括加速度传感器,陀螺仪传感器,磁传感器,压力传感器或温度传感器。
通信组件516被配置为便于终端500和其他设备之间有线或无线方式的通信。终端500可以接入基于通信标准的无线网络,如WiFi,2G或3G,或它们的组合。在一个示例性实施例中,通信部件516经由广播信道接收来自外部广播管理系统的广播信号或广播相关信息。在一个示例性实施例中,所述通信部件516还包括近场通信(NFC)模块,以促进短程通信。例如,在NFC模块可基于射频识别(RFID)技术,红外数据协会(IrDA)技术,超宽带(UWB)技术,蓝牙(BT)技术和其他技术来实现。
在示例性实施例中,终端500可以被一个或多个应用专用集成电路(ASIC)、数字信号处理器(DSP)、数字信号处理设备(DSPD)、可编程逻辑器件(PLD)、现场可编程门阵列(FPGA)、控制器、微控制器、微处理器或其他电子元件实现,用于执行上述图1或图2所对应的实施例中任一实施例所提供的组件调用方法。
本公开实施例提供的终端,通过在第二应用的数据目录中,确定第一组件,对第一组件进行包装,得到第二组件,在第一应用的运行过程中,当检测到对第二组件的调用指令时,在运行第一应用的进程中,运行第二组件。由于调用的第二组件运行在第一应用的进程中,第一应用的进程仍处于前台,能避免应用进程因处于后台而被终止的可能性,从而提高了系统运行时的稳定性。
在示例性实施例中,还提供了一种包括指令的非临时性计算机可读存储介质,例如包括指令的存储器504,上述指令可由终端500的处理器520执行以完成上述方法。例如,所述非临时性计算机可读存储介质可以是ROM、随机存取存储器(RAM)、CD-ROM、磁带、软盘和光数据存储设备等。
一种非临时性计算机可读存储介质,当所述存储介质中的指令由终端的处理器执行时,使得终端能够执行一种组件调用方法,该方法包括:
根据第一应用的调用需求,在第二应用的数据目录中,确定第一组件,所述第一组件为所述第一应用在运行过程中被调用的组件;
对所述第一组件进行包装,得到第二组件,所述第二组件的进程配置信息为所述第一应用的包名;
在所述第一应用的运行过程中,当检测到对所述第二组件的调用指令时,在运行所述第一应用的进程中,运行所述第二组件。
本公开实施例提供的计算机可读存储介质,通过在第二应用的数据目录中,确定第一组件,对第一组件进行包装,得到第二组件,在第一应用的运行过程中,当检测到对第二组件的调用指令时,在运行第一应用的进程中,运行第二组件。由于调用的第二组件运行在第一应用的进程中,第一应用的进程仍处于前台,能避免应用进程因处于后台而被终止的可能性,从而提高了系统运行时的稳定性。
本领域技术人员在考虑说明书及实践这里公开的发明后,将容易想到本发明的其它实施方案。本申请旨在涵盖本发明的任何变型、用途或者适应性变化,这些变型、用途或者适应性变化遵循本发明的一般性原理并包括本公开未公开的本技术领域中的公知常识或惯用技术手段。说明书和实施例仅被视为示例性的,本发明的真正范围和精神由下面的权利要求指出。
应当理解的是,本发明并不局限于上面已经描述并在附图中示出的精确结构,并且可以在不脱离其范围进行各种修改和改变。本发明的范围仅由所附的权利要求来限制。

Claims (11)

1.一种组件调用方法,其特征在于,所述方法包括:
根据第一应用的调用需求,在第二应用的数据目录中,确定第一组件,所述第一组件为所述第一应用在运行过程中被调用的组件;
对所述第一组件进行包装,得到第二组件,所述第二组件的进程配置信息为所述第一应用的包名;
在所述第一应用的运行过程中,当检测到对所述第二组件的调用指令时,在运行所述第一应用的进程中,运行所述第二组件。
2.根据权利要求1所述的方法,其特征在于,所述根据第一应用的调用需求,在第二应用的数据目录中,确定第一组件,包括:
根据第一应用的调用需求,确定第二应用的包名及第一组件名;
根据所述第二应用的包名与数据目录的对应关系,确定所述第二应用的数据目录;
根据所述第一组件名,在所述第二应用的数据目录下进行查找,找到对应的第一组件。
3.根据权利要求1所述的方法,其特征在于,所述根据第一应用的调用需求,在第二应用的数据目录中,确定第一组件之前,还包括:
将第一应用与第二应用下的数据设置为互相可见。
4.根据权利要求3所述的方法,其特征在于,所述将第一应用与第二应用下的数据设置为互相可见,包括:
将所述第一应用与所述第二应用设置为相同的分享标识;
通过相同的证书为所述第一应用及所述第二应用进行签名。
5.根据权利要求1所述的方法,其特征在于,所述对所述第一组件进行包装,得到第二组件,包括:
创建所述第一组件的包装类,将所述包装类作为第二组件;
或者,创建所述第一组件的派生类,将所述派生类作为第二组件。
6.一种组件调用装置,其特征在于,所述装置包括:
确定模块,用于根据第一应用的调用需求,在第二应用的数据目录中,确定第一组件,所述第一组件为所述第一应用在运行过程中被调用的组件;
包装模块,用于对所述第一组件进行包装,得到第二组件,所述第二组件的进程配置信息为所述第一应用的包名;
运行模块,用于在所述第一应用的运行过程中,当检测到对所述第二组件的调用指令时,在运行所述第一应用的进程中,运行所述第二组件。
7.根据权利要求6所述的装置,其特征在于,所述确定模块,用于根据第一应用的调用需求,确定第二应用的包名及第一组件名;根据所述第二应用的包名与数据目录的对应关系,确定所述第二应用的数据目录;根据所述第一组件名,在所述第二应用的数据目录下进行查找,找到对应的第一组件。
8.根据权利要求6所述的装置,其特征在于,所述装置还包括:
设置模块,用于将第一应用与第二应用下的数据设置为互相可见。
9.根据权利要求8所述的装置,其特征在于,所述设置模块,用于将所述第一应用与所述第二应用设置为相同的分享标识;通过相同的证书为所述第一应用及所述第二应用进行签名。
10.根据权利要求6所述的装置,其特征在于,所述包装模块,用于创建所述第一组件的包装类,将所述包装类作为第二组件;或者,创建所述第一组件的派生类,将所述派生类作为第二组件。
11.一种终端,其特征在于,包括:
处理器;
用于存储处理器可执行指令的存储器;
其中,所述处理器被配置为:
根据第一应用的调用需求,在第二应用的数据目录中,确定第一组件,所述第一组件为所述第一应用在运行过程中被调用的组件;
对所述第一组件进行包装,得到第二组件,所述第二组件的进程配置信息为所述第一应用的包名;
在所述第一应用的运行过程中,当检测到对所述第二组件的调用指令时,在运行所述第一应用的进程中,运行所述第二组件。
CN201510118066.5A 2015-03-18 2015-03-18 组件调用方法及装置 Active CN104765646B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201510118066.5A CN104765646B (zh) 2015-03-18 2015-03-18 组件调用方法及装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201510118066.5A CN104765646B (zh) 2015-03-18 2015-03-18 组件调用方法及装置

Publications (2)

Publication Number Publication Date
CN104765646A true CN104765646A (zh) 2015-07-08
CN104765646B CN104765646B (zh) 2018-02-23

Family

ID=53647492

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201510118066.5A Active CN104765646B (zh) 2015-03-18 2015-03-18 组件调用方法及装置

Country Status (1)

Country Link
CN (1) CN104765646B (zh)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN107463395A (zh) * 2016-06-03 2017-12-12 腾讯科技(深圳)有限公司 组件调用方法及装置
CN109189591A (zh) * 2018-08-30 2019-01-11 百度在线网络技术(北京)有限公司 用于调用应用组件的方法和装置
CN114461291A (zh) * 2020-10-22 2022-05-10 北京国双科技有限公司 应用程序组件调用方法、装置、电子设备及存储介质

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20140380283A1 (en) * 2013-06-25 2014-12-25 Purdue Research Foundation Systems and Methods of Detecting Power Bugs
CN104407981A (zh) * 2014-10-28 2015-03-11 小米科技有限责任公司 内存管理方法和装置

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20140380283A1 (en) * 2013-06-25 2014-12-25 Purdue Research Foundation Systems and Methods of Detecting Power Bugs
CN104407981A (zh) * 2014-10-28 2015-03-11 小米科技有限责任公司 内存管理方法和装置

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
LEMON: "跨进程调用Service(AIDL服务)", 《51CTO博客,930307.BLOG.51CTO.COM/7950022/1349494》 *

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN107463395A (zh) * 2016-06-03 2017-12-12 腾讯科技(深圳)有限公司 组件调用方法及装置
CN109189591A (zh) * 2018-08-30 2019-01-11 百度在线网络技术(北京)有限公司 用于调用应用组件的方法和装置
CN109189591B (zh) * 2018-08-30 2022-04-12 百度在线网络技术(北京)有限公司 用于调用应用组件的方法和装置
CN114461291A (zh) * 2020-10-22 2022-05-10 北京国双科技有限公司 应用程序组件调用方法、装置、电子设备及存储介质

Also Published As

Publication number Publication date
CN104765646B (zh) 2018-02-23

Similar Documents

Publication Publication Date Title
CN104869569A (zh) 应用程序的网络权限控制方法及装置
CN105138259A (zh) 操作执行方法及装置
CN104484200A (zh) 对固件进行升级的方法及装置
CN105511686A (zh) 来电处理方法、装置及终端电子设备
CN104766005A (zh) 应用软件访问权限的管理方法和装置
CN104980820A (zh) 多媒体文件播放方法及装置
CN104038536A (zh) 插件通信方法和装置
CN106203167A (zh) 应用权限管理方法及装置
CN104536935A (zh) 计算显示方法、计算编辑方法及装置
CN104837154A (zh) 无线访问接入点的控制方法及装置
CN103916468A (zh) 系统升级方法、终端、服务器及升级系统
CN105354017A (zh) 信息处理方法及装置
CN105224171A (zh) 图标显示方法、装置及终端
CN104407924A (zh) 内存优化方法及装置
CN104714826A (zh) 应用主题的加载方法及装置
CN104881304A (zh) 资源下载方法及装置
CN104317647A (zh) 应用功能实现方法、装置及终端
CN105183571A (zh) 函数调用方法和装置
CN105187671A (zh) 录音方法及装置
CN105488829A (zh) 生成头像的方法及装置
CN105577775A (zh) 双通道下载方法和装置
CN104951184A (zh) 应用程序下载方法及装置
CN104765646A (zh) 组件调用方法及装置
CN105487903A (zh) 系统升级方法及装置
CN105468606A (zh) 网页保存的方法及装置

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
EXSB Decision made by sipo to initiate substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant