CN114911755A - 一种应用程序管理方法、装置、计算设备及可读存储介质 - Google Patents

一种应用程序管理方法、装置、计算设备及可读存储介质 Download PDF

Info

Publication number
CN114911755A
CN114911755A CN202210298204.2A CN202210298204A CN114911755A CN 114911755 A CN114911755 A CN 114911755A CN 202210298204 A CN202210298204 A CN 202210298204A CN 114911755 A CN114911755 A CN 114911755A
Authority
CN
China
Prior art keywords
application program
name
program
application
acquiring
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.)
Pending
Application number
CN202210298204.2A
Other languages
English (en)
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.)
Wuhan Deepin Technology Co ltd
Original Assignee
Wuhan Deepin Technology Co ltd
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 Wuhan Deepin Technology Co ltd filed Critical Wuhan Deepin Technology Co ltd
Priority to CN202210298204.2A priority Critical patent/CN114911755A/zh
Publication of CN114911755A publication Critical patent/CN114911755A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/10File systems; File servers
    • G06F16/13File access structures, e.g. distributed indices
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/24Querying
    • G06F16/245Query processing
    • G06F16/2455Query execution
    • G06F16/24553Query execution of query operations
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/445Program loading or initiating
    • G06F9/44505Configuring for program initiating, e.g. using registry, configuration files

Abstract

本发明公开了一种应用程序管理方法,适于在操作系统中执行,操作系统驻留在计算设备中,计算设备包括启动应用程序容器,启动应用程序容器中包括启动的应用程序,方法包括:获取待处理的目标进程号;根据目标进程号获取目标进程号对应的第一包名;根据启动应用程序容器中的应用程序获取应用程序对应的第二包名;根据第一包名和第二包名获取目标进程号对应的目标应用程序。本发明一并公开了相应的装置、计算设备及可读存储介质。

Description

一种应用程序管理方法、装置、计算设备及可读存储介质
本申请是2021年02月25号提交的发明专利申请的分案申请,原申请的申请号:2021102141042,发明名称:一种应用程序管理方法、装置、计算设备及可读存储介质。
技术领域
本发明涉及应用程序管理领域,尤其涉及一种应用程序管理方法、装置、计算设备及可读存储介质。
背景技术
在Linux系统中,应用程序是静态文件,应用程序启动和使用过程中,操作系统会分配内存空间,在内存中运行,即进程,一个应用程序可以产生多个进程,在实际应用中,系统会首先获取到进程号,例如,某一应用程序启动,系统先获取到的是用于启动该应用程序的进程的进程号,进而根据获取到的进程号获取相应的应用程序,需要完成进程和应用程序之间的关联匹配。
关于Linux操作系统中进程号与应用程序的匹配技术,目前都是通过包管理工具来实现的,首先根据进程号获取应用程序的执行路径,然后通过dpkg-s来获取到相应进程号的包名,还需要通过dpkg-l来获取包名相关联文件信息,最后解析相关信息获取到desktop名称,通过desktop匹配到应用程序。这种应用程序匹配过程需要执行两次dpkg命令,同时需要信息解析才能完成,当同时启动多个进程时,很容易造成卡顿,影响应用程序的处理性能。同时,因为一个应用程序可能存在多个desktop名称,在进行相关联文件信息解析时,并不能准确解析出对应的desktop名称,导致应用程序匹配错误。
发明内容
为此,本发明提供了一种应用程序管理方法、装置、计算设备及可读存储介质,以力图解决或者至少缓解上面存在的问题。
根据本发明的一个方面,提供一种应用程序管理方法,适于在操作系统中执行,操作系统驻留在计算设备中,计算设备包括启动应用程序容器,启动应用程序容器中包括启动的应用程序,方法包括:获取待处理的目标进程号;根据目标进程号获取目标进程号对应的第一包名;根据启动应用程序容器中的应用程序获取应用程序对应的第二包名;根据第一包名和第二包名获取目标进程号对应的目标应用程序。
可选的,在根据本发明的应用程序管理方法中,计算设备包括程序数据库,程序数据库中包括应用程序的执行路径、包名以及桌面名称的关联关系。
可选的,在根据本发明的应用程序管理方法中,根据目标进程号获取目标进程号对应的第一包名包括:根据目标进程号获取对应的执行路径;根据执行路径及程序数据库获取目标进程号对应的第一包名。
可选的,在根据本发明的应用程序管理方法中,启动应用程序容器中还包括应用程序的桌面名称,根据启动应用程序容器中的应用程序获取应用程序对应的第二包名包括:从启动应用程序容器中获取应用程序的桌面名称;根据应用程序的桌面名称在程序数据库中获取应用程序对应的包名,并作为第二包名。
可选的,在根据本发明的应用程序管理方法中,根据第一包名和第二包名获取目标进程号对应的目标应用程序包括:遍历启动应用程序容器中的应用程序,获取应用程序对应的第二包名;当应用程序的第二包名与目标进程号的第一包名一致时,当前应用程序为目标应用程序;将第二包名存储到目标应用程序的相关信息中。
可选的,在根据本发明的应用程序管理方法中,程序数据库的构建过程包括以下步骤:获取操作系统中的所有应用程序安装包的包名;获取包名的相关联文件;从相关联文件中解析出包名所对应的应用程序的桌面名称和执行路径;将包名、桌面名称和执行路径相关联的存储到程序数据库中。
可选的,在根据本发明的应用程序管理方法中,还包括:当查询程序数据库时,判断程序数据库是否存在,当程序数据库不存在时,创建程序数据库。
根据本发明的又一个方面,提供一种应用程序管理装置,适于驻留在操作系统中,操作系统驻留在计算设备中,计算设备包括启动应用程序容器,启动应用程序容器中包括启动的应用程序,装置包括第一处理模块和第二处理模块,其中,第一处理模块,适于获取待处理的目标进程号,以便第二处理模块获取目标进程号对应的第一包名;还适于获取启动应用程序容器中的应用程序,以便第二处理模块获取应用程序对应的第二包名;还适于根据第一包名和第二包名获取目标进程号对应的目标应用程序;第二处理模块,适于获取目标进程号对应的第一包名,还适于获取应用程序对应的第二包名。
根据本发明的又一个方面,提供一种计算设备,包括:至少一个处理器;以及存储器,存储有程序指令,其中,程序指令被配置为适于由至少一个处理器执行,程序指令包括用于执行如上的应用程序管理方法的指令。
根据本发明的又一方面,提供一种存储有程序指令的可读存储介质,当程序指令被计算设备读取并执行时,使得计算设备执行如上的应用程序管理方法。
根据本发明的应用程序管理方法,根据获取到的进程号获取相应的第一包名,根据启动应用程序容器中的应用程序获取第二包名,当第二包名和第一包名一致时,则与当前第二包名对应的应用程序即为当前进程号所对应的应用程序,相较于根据desktop名称进行应用程序与进程号的匹配,包名的唯一确定性能够实现精确匹配。进一步地,根据本发明的应用程序管理方法,从进程号到包名的映射以及从应用程序到包名的映射是通过查询数据库和表完成的,相对于现有技术中的dpkg命令,查询速度更快,能够避免进程较多时出现卡顿的问题,提高应用程序的处理性能。
附图说明
为了实现上述以及相关目的,本文结合下面的描述和附图来描述某些说明性方面,这些方面指示了可以实践本文所公开的原理的各种方式,并且所有方面及其等效方面旨在落入所要求保护的主题的范围内。通过结合附图阅读下面的详细描述,本公开的上述以及其它目的、特征和优势将变得更加明显。遍及本公开,相同的附图标记通常指代相同的部件或元素。
图1示出了根据本发明一个实施例的计算设备100的框图;
图2示出了根据本发明一个实施例的应用程序管理方法200的流程图;
图3示出了根据本发明一个实施例的程序数据库的创建过程300的示意图;
图4示出了根据本发明一个实施例的应用程序管理装置400的框图。
具体实施方式
下面将参照附图更详细地描述本公开的示例性实施例。虽然附图中显示了本公开的示例性实施例,然而应当理解,可以以各种形式实现本公开而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本公开,并且能够将本公开的范围完整的传达给本领域的技术人员。
本发明的应用程序管理方法适于在操作系统中执行,操作系统适于驻留在计算设备中,图1示出了根据本发明一个实施例的计算设备100的示意图。需要说明的是,图1所示的计算设备100仅为一个示例,在实践中,用于实施本发明的应用程序管理方法的计算设备可以是任意型号的设备,其硬件配置情况可以与图1所示的计算设备100相同,也可以与图1所示的计算设备100不同。实践中用于实施本发明的应用程序管理方法的计算设备可以对图1所示的计算设备100的硬件组件进行增加或删减,本发明对计算设备的具体硬件配置情况不做限制。
如图1所示,在基本的配置102中,计算设备100典型地包括系统存储器106和一个或者多个处理器104。存储器总线108可以用于在处理器104和系统存储器106之间的通信。
取决于期望的配置,处理器104可以是任何类型的处理,包括但不限于:微处理器(μP)、微控制器(μC)、数字信息处理器(DSP)或者它们的任何组合。处理器104可以包括诸如一级高速缓存110和二级高速缓存112之类的一个或者多个级别的高速缓存、处理器核心114和寄存器116。示例的处理器核心114可以包括运算逻辑单元(ALU)、浮点数单元(FPU)、数字信号处理核心(DSP核心)或者它们的任何组合。示例的存储器控制器118可以与处理器104一起使用,或者在一些实现中,存储器控制器118可以是处理器104的一个内部部分。
取决于期望的配置,系统存储器106可以是任意类型的存储器,包括但不限于:易失性存储器(诸如RAM)、非易失性存储器(诸如ROM、闪存等)或者它们的任何组合。计算设备中的物理内存通常指的是易失性存储器RAM,磁盘中的数据需要加载至物理内存中才能够被处理器104读取。系统存储器106可以包括操作系统120、一个或者多个应用122以及程序数据124。在一些实施方式中,应用122可以布置为在操作系统上由一个或多个处理器104利用程序数据124执行指令。操作系统120例如可以是Linux、Unix、UOS等,其包括用于处理基本系统服务以及执行依赖于硬件的任务的程序指令。应用122包括用于实现各种用户期望的功能的程序指令,应用122例如可以是浏览器、即时通讯软件、软件开发工具(例如集成开发环境IDE、编译器等)等,但不限于此。当应用122被安装到计算设备100中时,可以向操作系统120添加驱动模块。
在计算设备100启动运行时,处理器104会从存储器106中读取操作系统120的程序指令并执行。应用122运行在操作系统120之上,利用操作系统120以及底层硬件提供的接口来实现各种用户期望的功能。当用户启动应用122时,应用122会加载至存储器106中,处理器104从存储器106中读取并执行应用122的程序指令。
计算设备100还包括储存设备132,储存设备132包括可移除储存器136和不可移除储存器138,可移除储存器136和不可移除储存器138均与储存接口总线134连接。
计算设备100还可以包括有助于从各种接口设备(例如,输出设备142、外设接口144和通信设备146)到基本配置102经由总线/接口控制器130的通信的接口总线140。示例的输出设备142包括图形处理单元148和音频处理单元150。它们可以被配置为有助于经由一个或者多个A/V端口152与诸如显示器或者扬声器之类的各种外部设备进行通信。示例外设接口144可以包括串行接口控制器154和并行接口控制器156,它们可以被配置为有助于经由一个或者多个I/O端口158和诸如输入设备(例如,键盘、鼠标、笔、语音输入设备、触摸输入设备)或者其他外设(例如打印机、扫描仪等)之类的外部设备进行通信。示例的通信设备146可以包括网络控制器160,其可以被布置为便于经由一个或者多个通信端口164与一个或者多个其他计算设备162通过网络通信链路的通信。
网络通信链路可以是通信介质的一个示例。通信介质通常可以体现为在诸如载波或者其他传输机制之类的调制数据信号中的计算机可读指令、数据结构、程序模块,并且可以包括任何信息递送介质。“调制数据信号”可以这样的信号,它的数据集中的一个或者多个或者它的改变可以在信号中编码信息的方式进行。作为非限制性的示例,通信介质可以包括诸如有线网络或者专线网络之类的有线介质,以及诸如声音、射频(RF)、微波、红外(IR)或者其它无线介质在内的各种无线介质。这里使用的术语计算机可读介质可以包括存储介质和通信介质二者。
在根据本发明的计算设备100中,操作系统120包括用于执行本发明的应用程序管理方法200的指令,以实现进程号与应用程序之间的匹配。
图2示出了根据本发明一个实施例的应用程序管理方法200的流程图,方法200适于在计算设备(如图1所示)中的操作系统中执行。
如图2所示,方法200始于步骤S210,获取用户对应用程序的操作,包括启动应用程序或者关闭应用程序。以启动应用程序“安全中心”为例进行说明,进入步骤S220。
在步骤S220中,将应用程序及其相关信息写入启动应用程序容器,包括应用程序名称、desktop名称(即桌面名称)、应用程序ID、应用程序图片、应用程序分类、应用程序安装时间等信息。
上述启动应用程序“安全中心”实施例中,写入启动应用程序容器的相关信息为:
{
desktop名称:“/usr/share/applications/deepin-defender.desktop”,
应用程序名称:“安全中心”,
应用程序ID:“deepin-defender”,
应用程序图片:“deepin-defender”,
应用程序分类:9,
应用程序安装时间:1600669865
}
随后进入步骤S230,获取到启动应用程序的进程号,Linux操作系统内核在检测到应用程序启动时会分配相应的进程完成应用程序启动,首先被获取到的也是该进程的进程号,在获取到进程号(即目标进程号)后进入步骤S240。
在步骤S240中,根据进程号获取该进程号对应的包名(即第一包名)。根据本发明的一个实施例,计算设备中包含一个程序数据库,该数据库中存储有应用程序的执行路径、桌面名称和包名的对应关系,本步骤中根据进程号和程序数据库可以获取到目标进程号对应的包名,由于数据库中并没有进程号的信息,需要首先将进程号对应到执行路径,例如进程号为6311,可以通过getFilePathByLink(“/proc/6311/exe”)得到对应的执行路径,还可以通过fs.open(“/proc/6311/cmdline”)得到,获取到的执行路径为“/usr/bin/deepin-defender”,根据该执行路径在程序数据库中搜索,获取对应的包名,程序数据库中包括如表1中的数据记录,其中,desktop_name对应desktop名称,exe_path对应执行路径,pkg_name对应包名,则查询到的对应的包名(第一包名)为“deepin-defender”。
表1
Figure BDA0003562491130000071
根据本发明的一个实施例,本步骤中首先判断程序数据库是否存在,如果不存在,首先创建该数据库,避免程序数据库被误删后,无法完成进程号和包名的匹配,程序数据库的创建过程在程序数据库的创建过程300中具体说明,此处不再赘述。
在随后的步骤S250中,根据启动应用程序容器中的应用程序获取应用程序对应的第二包名。应用程序容器中包含当前所有启动运行中的应用程序的关信息,如desktop名称、应用程序名称、应用程序ID、应用程序图片、应用程序分类、应用程序安装时间等。在本步骤中,根据预定顺序遍历启动应用程序容器中的应用程序,例如,从后向前,获取应用程序的desktop名称,根据desktop名称从程序数据库中查询相应的包名(即第二包名)。
在上述步骤S240和步骤S250中均采用查询数据库的方式实现了包名的获取,相较于执行dpkg命令,查询速度更快。
随后进入步骤S260,判断第二包名是否与第一包名一致。根据本发明的一个实施例,应用程序对应的第二包名与进程号对应的第一包名不一致,则进入步骤S250,获取启动应用程序容器中的下一个应用程序的desktop名称对应的包名,作为新的第二包名,当启动应用程序容器中的desktop名称对应的包名没有与第一包名匹配时,说明进程号与应用程序匹配失败。
根据本发明的又一个实施例,以应用程序“安全中心”为例,根据desktop名称“/usr/share/applications/deepin-defender.desktop”查询表1,获得相应的包名deepin-defender,与根据进程号6311获取到的第一包名一致,则在步骤S270中,第二包名对应的应用程序“安全中心”与第一包名对应的进程号为6311的进程匹配成功。
在本步骤中,可以将第二包名添加到启动应用程序容器中的应用程序相关信息中,继续以“安全中心”的相关信息为例,相关信息中增加包名信息,如下。
{
desktop名称:“/usr/share/applications/deepin-defender.desktop”,
应用程序名称:“安全中心”,
应用程序ID:“deepin-defender”,
应用程序图片:“deepin-defender”,
应用程序分类:9,
应用程序安装时间:1600669865,
包名:“deepin-defender”
}
图3示出了根据本发明一个实施例的程序数据库的创建过程300的流程图。如图3所示,该过程始于步骤S310,在本步骤中,首先创建数据库,以MySQL数据库为例,可以通过create database datebase1命令完成数据库的创建,其中database1为程序数据库名称,并通过create table创建表,例如,create table T1(desktop_name char(30),exe_pathchar(30),pkg_name char(30)),其中,desktop_name为desktop名称,exe_path为执行路径,pkg_name为包名。本步骤中,也可以创建其他类型的数据库,本发明对此不做限制,。
随后进入步骤S320,获取操作系统中所有应用程序安装包的包名。
随后进入步骤S330中,获取所有包名的相关联文件信息。根据本发明的一个实施例,可以通过dpkg-query查询所有包相关联文件信息。
随后进入步骤S340中,从相关联文件信息中解析出desktop名称和执行路径,并与包名相关联的存储到程序数据库表中,例如,通过insert命令将数据插入表中,例如:insert into T1(“/usr/share/applications/deepin-defender.desktop”,“/usr/bin/deepin-defender”,“deepin-defender”)。将所有包名对应的desktop名称和执行路径都存储到数据库表中,完成程序数据库的创建。
图4示出了根据本发明一个实施例的应用程序管理装置400的框图,装置400适于驻留在计算设备的操作系统中,计算设备包括启动应用程序容器和程序数据库,其中启动应用程序容器中存储有应用程序与desktop名称的对应关系,程序数据库中存储有应用程序的执行路径、desktop名称与包名的对应关系。
如图4所示,装置400包括第一处理模块410和第二处理模块420。其中,第一处理模块410适于获取待处理的进程号,并将进程号对应到执行路径,以便第二处理模块通过该执行路径在程序数据库中获取当前处理的进程号对应的包名(即第一包名),其中,所述目标进程号对应一个目标应用程序;第一处理模块410与启动应用程序容器连接,还适于获取启动应用程序容器中的应用程序所对应的desktop名称,以便第二处理模块420根据该desktop名称获取应用程序对应的第二包名;还适于根据第一包名和第二包名获取目标进程号对应的目标应用程序,当第二包名与第一包名一致时,与第二包名对应的应用程序即为与第一包名对应的进程所对应的应用程序。
第二处理模块420与程序数据库连接,适于在接收到第一处理模块410发送的执行路径时,获取相应的第一包名,在接收到第一处理模块410发送的desktop名称时,根据desktop名称获取对应的第二包名,并将第一包名和第二包名返回给第一处理模块410。
根据本发明的应用程序管理方法,根据获取到的进程号获取相应的第一包名,根据启动应用程序容器中的应用程序获取第二包名,当第二包名和第一包名一致时,则当前第二包名对应的应用程序即为当前进程号所对应的应用程序,相较于根据desktop名称进行应用程序与进程号的匹配,包名的唯一确定性能够实现精确匹配。进一步地,根据本发明的应用程序管理方法,从进程号到包名的映射以及从应用程序到包名的映射是通过查询数据库和表完成的,相对于现有技术中的dpkg命令,查询速度更快,能够避免进程较多时出现卡顿的问题,提高应用程序的处理性能。
这里描述的各种技术可结合硬件或软件,或者它们的组合一起实现。从而,本发明的方法和设备,或者本发明的方法和设备的某些方面或部分可采取嵌入有形媒介,例如可移动硬盘、U盘、软盘、CD-ROM或者其它任意机器可读的存储介质中的程序代码(即指令)的形式,其中当程序被载入诸如计算机之类的机器,并被所述机器执行时,所述机器变成实践本发明的设备。
在程序代码在可编程计算机上执行的情况下,计算设备一般包括处理器、处理器可读的存储介质(包括易失性和非易失性存储器和/或存储元件),至少一个输入装置,和至少一个输出装置。其中,存储器被配置用于存储程序代码;处理器被配置用于根据该存储器中存储的所述程序代码中的指令,执行本发明的应用程序管理方法。
以示例而非限制的方式,可读介质包括可读存储介质和通信介质。可读存储介质存储诸如计算机可读指令、数据结构、程序模块或其它数据等信息。通信介质一般以诸如载波或其它传输机制等已调制数据信号来体现计算机可读指令、数据结构、程序模块或其它数据,并且包括任何信息传递介质。以上的任一种的组合也包括在可读介质的范围之内。
在此处所提供的说明书中,算法和显示不与任何特定计算机、虚拟系统或者其它设备固有相关。各种通用系统也可以与本发明的示例一起使用。根据上面的描述,构造这类系统所要求的结构是显而易见的。此外,本发明也不针对任何特定编程语言。应当明白,可以利用各种编程语言实现在此描述的本发明的内容,并且上面对特定语言所做的描述是为了披露本发明的最佳实施方式。
在此处所提供的说明书中,说明了大量具体细节。然而,能够理解,本发明的实施例可以在没有这些具体细节的情况下被实践。在一些实例中,并未详细示出公知的方法、结构和技术,以便不模糊对本说明书的理解。
应当理解,为了精简本公开并帮助理解各个发明方面中的一个或多个,在上面对本发明的示例性实施例的描述中,本发明的各个特征有时被一起分组到单个实施例、图、或者对其的描述中。然而,并不应将该公开的方法解释成反映如下意图:即所要求保护的本发明要求比在每个权利要求中所明确记载的特征更多特征。更确切地说,如下面的权利要求书所反映的那样,发明方面在于少于前面公开的单个实施例的所有特征。因此,遵循具体实施方式的权利要求书由此明确地并入该具体实施方式,其中每个权利要求本身都作为本发明的单独实施例。
本领域那些技术人员应当理解在本文所公开的示例中的设备的模块或单元或组件可以布置在如该实施例中所描述的设备中,或者可替换地可以定位在与该示例中的设备不同的一个或多个设备中。前述示例中的模块可以组合为一个模块或者此外可以分成多个子模块。
本领域那些技术人员可以理解,可以对实施例中的设备中的模块进行自适应性地改变并且把它们设置在与该实施例不同的一个或多个设备中。可以把实施例中的模块或单元或组件组合成一个模块或单元或组件,以及此外可以把它们分成多个子模块或子单元或子组件。除了这样的特征和/或过程或者单元中的至少一些是相互排斥之外,可以采用任何组合对本说明书(包括伴随的权利要求、摘要和附图)中公开的所有特征以及如此公开的任何方法或者设备的所有过程或单元进行组合。除非另外明确陈述,本说明书(包括伴随的权利要求、摘要和附图)中公开的每个特征可以由提供相同、等同或相似目的的替代特征来代替。
此外,本领域的技术人员能够理解,尽管在此所述的一些实施例包括其它实施例中所包括的某些特征而不是其它特征,但是不同实施例的特征的组合意味着处于本发明的范围之内并且形成不同的实施例。例如,在下面的权利要求书中,所要求保护的实施例的任意之一都可以以任意的组合方式来使用。
此外,所述实施例中的一些在此被描述成可以由计算机系统的处理器或者由执行所述功能的其它装置实施的方法或方法元素的组合。因此,具有用于实施所述方法或方法元素的必要指令的处理器形成用于实施该方法或方法元素的装置。此外,装置实施例的在此所述的元素是如下装置的例子:该装置用于实施由为了实施该发明的目的的元素所执行的功能。
如在此所使用的那样,除非另行规定,使用序数词“第一”、“第二”、“第三”等等来描述普通对象仅仅表示涉及类似对象的不同实例,并且并不意图暗示这样被描述的对象必须具有时间上、空间上、排序方面或者以任意其它方式的给定顺序。
尽管根据有限数量的实施例描述了本发明,但是受益于上面的描述,本技术领域内的技术人员明白,在由此描述的本发明的范围内,可以设想其它实施例。此外,应当注意,本说明书中使用的语言主要是为了可读性和教导的目的而选择的,而不是为了解释或者限定本发明的主题而选择的。因此,在不偏离所附权利要求书的范围和精神的情况下,对于本技术领域的普通技术人员来说许多修改和变更都是显而易见的。对于本发明的范围,对本发明所做的公开是说明性的,而非限制性的,本发明的范围由所附权利要求书限定。

Claims (9)

1.一种应用程序管理方法,适于在操作系统中执行,所述操作系统驻留在计算设备中,所述计算设备包括启动应用程序容器,所述启动应用程序容器中包括启动的应用程序,所述方法包括:
获取待处理的目标进程号;
根据所述目标进程号获取所述目标进程号对应的第一包名;
根据所述启动应用程序容器中的应用程序获取所述应用程序对应的第二包名;
根据所述第一包名和第二包名获取所述目标进程号对应的目标应用程序;
其中,所述启动应用程序容器中还包括应用程序的桌面名称,所述根据所述启动应用程序容器中的应用程序获取所述应用程序对应的第二包名包括:
从所述启动应用程序容器中获取应用程序的桌面名称;
根据所述应用程序的桌面名称在所述程序数据库中获取所述应用程序对应的包名,并作为第二包名。
2.如权利要求1所述的方法,其中,所述计算设备包括程序数据库,所述程序数据库中包括应用程序的执行路径、包名以及桌面名称的关联关系。
3.如权利要求1所述的方法,其中,所述根据所述目标进程号获取所述目标进程号对应的第一包名包括:
根据所述目标进程号获取对应的执行路径;
根据所述执行路径及程序数据库获取所述目标进程号对应的第一包名。
4.如权利要求1-3中任意一项所述的方法,其中,所述根据所述第一包名和第二包名获取所述目标进程号对应的目标应用程序包括:
遍历所述启动应用程序容器中的应用程序,获取所述应用程序对应的第二包名;
当所述应用程序的第二包名与所述目标进程号的第一包名一致时,当前所述应用程序为目标应用程序;
将所述第二包名存储到所述目标应用程序的相关信息中。
5.如权利要求1-4中任意一项所述的方法,其中,所述程序数据库的构建过程包括以下步骤:
获取所述操作系统中的所有应用程序安装包的包名;
获取所述包名的相关联文件;
从所述相关联文件中解析出包名所对应的应用程序的桌面名称和执行路径;
将所述包名、桌面名称和执行路径相关联的存储到所述程序数据库中。
6.如权利要求2-5中任意一项所述的方法,所述方法还包括:
当查询所述程序数据库时,判断所述程序数据库是否存在,当所述程序数据库不存在时,创建所述程序数据库。
7.一种应用程序管理装置,适于驻留在操作系统中,所述操作系统驻留在计算设备中,所述计算设备包括启动应用程序容器,所述启动应用程序容器中包括启动的应用程序,所述装置包括第一处理模块和第二处理模块,其中,
第一处理模块,适于获取待处理的目标进程号,以便所述第二处理模块获取所述目标进程号对应的第一包名;还适于获取启动应用程序容器中的应用程序,以便所述第二处理模块获取所述应用程序对应的第二包名;还适于根据所述第一包名和第二包名获取所述目标进程号对应的目标应用程序;
第二处理模块,适于获取所述目标进程号对应的第一包名,还适于获取应用程序对应的第二包名;
其中,所述启动应用程序容器中还包括应用程序的桌面名称,所述根据所述启动应用程序容器中的应用程序获取所述应用程序对应的第二包名包括:
从所述启动应用程序容器中获取应用程序的桌面名称;
根据所述应用程序的桌面名称在所述程序数据库中获取所述应用程序对应的包名,并作为第二包名。
8.一种计算设备,包括:
至少一个处理器;以及
存储器,存储有程序指令,其中,所述程序指令被配置为适于由所述至少一个处理器执行,所述程序指令包括用于执行如权利要求1-6中任一项所述方法的指令。
9.一种存储有程序指令的可读存储介质,当所述程序指令被计算设备读取并执行时,使得所述计算设备执行如权利要求1-6中任一项所述方法。
CN202210298204.2A 2021-02-25 2021-02-25 一种应用程序管理方法、装置、计算设备及可读存储介质 Pending CN114911755A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202210298204.2A CN114911755A (zh) 2021-02-25 2021-02-25 一种应用程序管理方法、装置、计算设备及可读存储介质

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
CN202110214104.2A CN113032038B (zh) 2021-02-25 2021-02-25 一种应用程序管理方法、装置、计算设备及可读存储介质
CN202210298204.2A CN114911755A (zh) 2021-02-25 2021-02-25 一种应用程序管理方法、装置、计算设备及可读存储介质

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
CN202110214104.2A Division CN113032038B (zh) 2021-02-25 2021-02-25 一种应用程序管理方法、装置、计算设备及可读存储介质

Publications (1)

Publication Number Publication Date
CN114911755A true CN114911755A (zh) 2022-08-16

Family

ID=76461549

Family Applications (2)

Application Number Title Priority Date Filing Date
CN202110214104.2A Active CN113032038B (zh) 2021-02-25 2021-02-25 一种应用程序管理方法、装置、计算设备及可读存储介质
CN202210298204.2A Pending CN114911755A (zh) 2021-02-25 2021-02-25 一种应用程序管理方法、装置、计算设备及可读存储介质

Family Applications Before (1)

Application Number Title Priority Date Filing Date
CN202110214104.2A Active CN113032038B (zh) 2021-02-25 2021-02-25 一种应用程序管理方法、装置、计算设备及可读存储介质

Country Status (1)

Country Link
CN (2) CN113032038B (zh)

Family Cites Families (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8893222B2 (en) * 2012-11-13 2014-11-18 Auckland Uniservices Ltd. Security system and method for the android operating system
CN104102539B (zh) * 2013-04-09 2019-06-28 腾讯科技(深圳)有限公司 获取移动终端应用程序调用的底层库的方法及装置
EP3137989A4 (en) * 2014-04-30 2018-01-03 Pivotal Software, Inc. Fast deployment across cloud platforms
CN104869569A (zh) * 2015-03-31 2015-08-26 小米科技有限责任公司 应用程序的网络权限控制方法及装置
CN106547634B (zh) * 2016-11-28 2020-07-31 武汉斗鱼网络科技有限公司 一种跨进程通信的方法及装置
CN108228770A (zh) * 2017-12-27 2018-06-29 青岛海信移动通信技术股份有限公司 一种应用文件来源查询的方法及装置
CN110489168B (zh) * 2019-07-31 2021-07-27 长飞光纤光缆股份有限公司 一种gnome只读桌面系统的制作方法及装置

Also Published As

Publication number Publication date
CN113032038A (zh) 2021-06-25
CN113032038B (zh) 2022-05-03

Similar Documents

Publication Publication Date Title
US9880889B2 (en) Virtual application extension points
CN111563024B (zh) 一种宿主机上监控容器进程的方法、装置及计算设备
CN107563201B (zh) 基于机器学习的关联样本查找方法、装置及服务器
US10761822B1 (en) Synchronization of computation engines with non-blocking instructions
CN112346668B (zh) 一种光盘信息获取方法、计算设备及可读存储介质
CN111428241B (zh) 一种多安全访问策略控制方法及计算设备
CN106227893A (zh) 一种文件类型获取方法及装置
CN107577943B (zh) 基于机器学习的样本预测方法、装置及服务器
CN112379888A (zh) 一种代码变更分析方法
CN110023938A (zh) 利用函数长度统计确定文件相似度的系统和方法
CN114924810A (zh) 一种异构程序执行方法、装置、计算设备及可读存储介质
CN113204385A (zh) 一种插件加载方法、装置、计算设备及可读存储介质
CN113032038B (zh) 一种应用程序管理方法、装置、计算设备及可读存储介质
US20210149881A1 (en) Method and system for identifying information objects using deep ai-based knowledge objects
WO2015124086A1 (en) Virus signature matching method and apparatus
CN114816772B (zh) 基于兼容层运行的应用的排错方法、排错系统及计算设备
CN111694992A (zh) 一种数据处理方法和装置
CN113254397B (zh) 一种数据检查方法及计算设备
CN110442380B (zh) 一种数据预热方法及计算设备
CN111563259B (zh) 一种傀儡进程检测方法、装置、可读存储介质及计算设备
CN111913814A (zh) 对象拷贝方法及计算设备
CN117271440B (zh) 一种基于freeRTOS文件信息存储方法、读取方法及相关设备
CN113722715B (zh) 一种导入文件检查方法、检查系统及计算设备
US11841792B1 (en) Instructions with multiple memory access modes
US11188302B1 (en) Top value computation on an integrated circuit device

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination