CN113485769B - 一种应用程序运行方法、计算设备及存储介质 - Google Patents

一种应用程序运行方法、计算设备及存储介质 Download PDF

Info

Publication number
CN113485769B
CN113485769B CN202110836043.3A CN202110836043A CN113485769B CN 113485769 B CN113485769 B CN 113485769B CN 202110836043 A CN202110836043 A CN 202110836043A CN 113485769 B CN113485769 B CN 113485769B
Authority
CN
China
Prior art keywords
plug
ins
type
application program
interface
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.)
Active
Application number
CN202110836043.3A
Other languages
English (en)
Other versions
CN113485769A (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.)
Uniontech Software Technology Co Ltd
Original Assignee
Uniontech Software 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 Uniontech Software Technology Co Ltd filed Critical Uniontech Software Technology Co Ltd
Priority to CN202110836043.3A priority Critical patent/CN113485769B/zh
Publication of CN113485769A publication Critical patent/CN113485769A/zh
Application granted granted Critical
Publication of CN113485769B publication Critical patent/CN113485769B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • 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/44521Dynamic linking or loading; Link editing at or after load time, e.g. Java class loading
    • G06F9/44526Plug-ins; Add-ons
    • 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

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Stored Programmes (AREA)

Abstract

本发明公开了一种应用程序运行方法,适于在计算设备中执行,计算设备中存储有插件库,插件库中包括多个插件,方法包括步骤:运行应用程序的主程序;从插件库中选取多个插件,并将每个插件安装到应用程序的主程序;确定主程序中所安装插件中的第一类型插件和第二类型插件,第一类型插件为在应用程序的主界面中运行的插件,第二类型插件为以插件界面形式运行的插件;加载第一类型插件,并根据第一类型插件渲染和加载应用程序的主界面;加载第二类型插件,以便根据第二类型插件加载对应的插件界面。本发明还一并公开了一种计算设备和计算机可读存储介质。

Description

一种应用程序运行方法、计算设备及存储介质
技术领域
本发明涉及软件架构领域,特别涉及一种应用程序运行方法、计算设备及存储介质。
背景技术
随着计算机技术的发展,人们对于应用程序这一种重要的人机媒介提出了更高的要求,需要应用程序承载更多的功能,满足更多的需求。应用程序的更新和发展使得应用程序的体积越来越大,尤其是应用程序的主程序的业务逻辑代码越来越多,其中还构建有多级多分支的页面跳转关系。
由于上述情况,应用程序在加载和打开的速度也逐渐变慢,程序界面之间的跳转也不够流畅。应用程序包括多个页面时,页面之间的通信也往往需要经过主页面转发,当应用程序越来越多,多个页面之间的消息传输也由于应用页面的增长变得繁杂。
为此,需要一种新的应用程序运行方法。
发明内容
为此,本发明提供一种应用程序运行方法,以力图解决或者至少缓解上面存在的问题。
根据本发明的一个方面,提供一种应用程序运行方法,适于在计算设备中执行,计算设备中存储有插件库,插件库中包括多个插件,方法包括步骤:运行应用程序的主程序;从插件库中选取多个插件,并将每个插件安装到应用程序的主程序;确定主程序中所安装插件中的第一类型插件和第二类型插件,第一类型插件为在应用程序的主界面中运行的插件,第二类型插件为以插件界面形式运行的插件;加载第一类型插件,并根据第一类型插件渲染和加载应用程序的主界面;加载第二类型插件,以便根据第二类型插件加载对应的插件界面。
可选地,在根据本发明的方法中,运行应用程序的主程序包括步骤:创建应用程序的线程池,线程池包括多个线程,适于处理不同插件之间的通信任务。
可选地,在根据本发明的方法中,计算设备中还存储有插件数据库,插件数据库适于存储和查询插件的配置文件,将每个插件安装到应用程序的主程序包括步骤:从插件数据库中获取插件的配置文件;根据配置文件调用对应的插件启动器在主程序中注册服务接口和一个或多个服务事件,服务事件关联有一项或多项事件数据;当插件需要将事件数据传输到其他插件时,将事件数据通过服务接口,以通信任务的形式发布至应用程序的线程池,通过线程池处理通信任务将事件数据传输到其他插件。
可选地,在根据本发明的方法中,还包括步骤:通过插件启动器设置插件订阅的服务事件;当线程池处理所述通信任务时,确定通信任务的事件数据所对应的服务事件,将所述事件数据发送至订阅该服务事件的插件。
可选地,在根据本发明的方法中,服务事件包括对应的主题名,将事件数据通过服务接口,以通信任务的形式发布至应用程序的线程池包括步骤:根据事件数据对应的服务事件的主题名以及通信数据生成通信任务发布至线程池;线程池处理通信任务时,确定通信任务的事件数据所对应的服务事件包括步骤:根据通信任务的主题名确定通信数据对应的服务事件。
可选地,在根据本发明的方法中,还包括步骤:若从插件数据库中未获取到插件的配置文件,则从插件库中获取对应插件的配置文件并存储到插件数据库;根据插件的配置文件创建插件的插件启动器。
可选地,在根据本发明的方法中,加载第一类型插件包括步骤:根据在插件数据库中存储的第一类型插件的配置文件,确定第一类型插件的存储路径,启动所述第一类型插件。
可选地,在根据本发明的方法中,运行应用程序的主程序还包括步骤:在主程序中创建插件框架,以便根据插件框架安装和加载插件;当需要关闭插件时,通过述插件框架调用析构函数,将插件从插件框架进行卸载,以便回收插件资源。
根据本发明的另一方面,提供了一种计算设备,包括:一个或多个处理器;存储器;以及一个或多个程序,其中一个或多个程序存储在存储器中并被配置为由一个或多个处理器执行,一个或多个程序包括用于执行根据本发明的一种应用程序运行方法的任一方法的指令。
根据本发明的还有一个方面,提供了一种存储一个或多个程序的计算机可读存储介质,一个或多个程序包括指令,该指令当由计算设备执行时,使得计算设备执行根据本发明的一种应用程序运行方法中的任一方法。
本发明中的应用程序运行方法适于在计算设备中执行,计算设备中存储有插件库,插件库中包括多个插件,每个插件承载一项应用功能。在运行应用程序时,首先运行应用程序的主程序。随后从插件库中选取多个插件,并将每个插件安装到应用程序的主程序,以便实现相应的应用功能。在进行应用的加载时,首先加载第一类型插件,第一类型插件为在应用程序的主界面中运行的插件。接着根据第一类型插件渲染和加载应用程序的主界面,以便实现快速打开应用的主界面,缩短应用的打开时间,提高用户的使用体验。再打开应用程序的主界面后,再加载第二类型插件,以便根据第二类型插件加载对应的插件界面,以实现主界面之外的应用功能。
进一步的,本发明中将页面插件化,将页面之间的通信转化为插件之间的通信。具体的,从插件数据库中获取插件的配置文件,根据配置文件调用对应的插件启动器在主程序中注册服务接口和一个或多个服务事件,服务事件关联有一项或多项事件数据。当插件需要将事件数据传输到其他插件时,将事件数据通过服务接口,以通信任务的形式发布至应用程序的线程池,通过线程池处理通信任务将事件数据传输到其他插件。从而能够减少页面之间的数据相应时间。
附图说明
为了实现上述以及相关目的,本文结合下面的描述和附图来描述某些说明性方面,这些方面指示了可以实践本文所公开的原理的各种方式,并且所有方面及其等效方面旨在落入所要求保护的主题的范围内。通过结合附图阅读下面的详细描述,本公开的上述以及其它目的、特征和优势将变得更加明显。遍及本公开,相同的附图标记通常指代相同的部件或元素。
图1示出了根据本发明一个示范性实施例的应用程序的架构示意图;
图2示出了根据本发明一个示范性实施例的计算设备200的结构框图;
图3示出了根据本发明一个示范性实施例的应用程序运行方法300的流程示意图;
图4a示出了根据本发明一个示范性实施例的主界面的示意图;以及
图4b示出了根据本发明一个示范性实施例的插件界面的示意图。
具体实施方式
下面将参照附图更详细地描述本公开的示例性实施例。虽然附图中显示了本公开的示例性实施例,然而应当理解,可以以各种形式实现本公开而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本公开,并且能够将本公开的范围完整的传达给本领域的技术人员。相同的附图标记通常指代相同的部件或元素。
本发明的应用程序运行方法适于在计算设备中执行。图2示出了根据本发明一个示范性实施例的计算设备200的结构框图。如图2所示,在基本的配置202中,计算设备200典型地包括系统存储器206和一个或者多个处理器204。存储器总线208可以用于在处理器204和系统存储器206之间的通信。
取决于期望的配置,处理器204可以是任何类型的处理,包括但不限于:微处理器(μP)、微控制器(μC)、数字信息处理器(DSP)或者它们的任何组合。处理器204可以包括诸如一级高速缓存210和二级高速缓存212之类的一个或者多个级别的高速缓存、处理器核心214和寄存器216。示例的处理器核心214可以包括运算逻辑单元(ALU)、浮点数单元(FPU)、数字信号处理核心(DSP核心)或者它们的任何组合。示例的存储器控制器218可以与处理器204一起使用,或者在一些实现中,存储器控制器218可以是处理器204的一个内部部分。
取决于期望的配置,系统存储器206可以是任意类型的存储器,包括但不限于:易失性存储器(诸如RAM)、非易失性存储器(诸如ROM、闪存等)或者它们的任何组合。系统存储器206可以包括操作系统220、一个或者多个程序222以及程序数据228。在一些实施方式中,程序222可以布置为在操作系统上由一个或者多个处理器204利用程序数据228执行根据本发明的方法300的指令223。
计算设备200还可以包括储存接口总线234。储存接口总线234实现了从储存设备232(例如,可移除储存器236和不可移除储存器238)经由总线/接口控制器230到基本配置202的通信。操作系统220、程序222以及数据224的至少一部分可以存储在可移除储存器236和/或不可移除储存器238上,并且在计算设备200上电或者要执行程序222时,经由储存接口总线234而加载到系统存储器206中,并由一个或者多个处理器204来执行。
计算设备200还可以包括有助于从各种接口设备(例如,输出设备242、外设接口244和通信设备246)到基本配置202经由总线/接口控制器230的通信的接口总线240。示例的输出设备242包括图形处理单元248和音频处理单元250。它们可以被配置为有助于经由一个或者多个A/V端口252与诸如显示器或者扬声器之类的各种外部设备进行通信。示例外围接口244可以包括串行接口控制器254和并行接口控制器256,它们可以被配置为有助于经由一个或者多个I/O端口258和诸如输入设备(例如,键盘、鼠标、笔、语音输入设备、触摸输入设备)或者其他外设(例如打印机、扫描仪等)之类的外部设备进行通信。示例的通信设备246可以包括网络控制器260,其可以被布置为以便经由一个或者多个通信端口264与一个或者多个其他计算设备262通过网络通信链路的通信。
网络通信链路可以是通信介质的一个示例。通信介质通常可以体现为在诸如载波或者其他传输机制之类的调制数据信号中的计算机可读指令、数据结构、程序模块,并且可以包括任何信息递送介质。“调制数据信号”可以这样的信号,它的数据集中的一个或者多个或者它的改变可以在信号中编码信息的方式进行。作为非限制性的示例,通信介质可以包括诸如有线网络或者专线网络之类的有线介质,以及诸如声音、射频(RF)、微波、红外(IR)或者其它无线介质在内的各种无线介质。这里使用的术语计算机可读介质可以包括存储介质和通信介质二者。
在根据本发明的计算设备200中,程序222包括应用程序运行方法300的多条程序指令,这些程序指令可以指示处理器204执行本发明的计算设备200中运行的应用程序运行方法300中的部分步骤,以便计算设备200中的各部分通过执行本发明的应用程序运行方法300来运行应用程序。
计算设备200可以实现为服务器,例如文件服务器240、数据库250、服务器、应用程序服务器等,这些电子设备可以是诸如个人数字助理(PDA)、无线网络浏览设备、应用专用设备、或者可以包括上面任何功能的混合设备。可以实现为包括桌面计算机和笔记本计算机配置的个人计算机,也在一些实施例中,计算设备200被配置为执行应用程序运行方法300。
图3示出了根据本发明的一个示范性实施例的应用程序运行方法300的流程示意图。方法300适于在服务器140中执行,可具体实现为在计算设备200中执行。如图3所示,应用程序运行方法300始于步骤S310,运行应用程序的主程序。为了更清楚对方法300进行说明,采用图1对应用程序的架构进行说明。图1示出了根据本发明一个示范性实施例的应用程序的架构示意图。
如图1所示,在计算设备中配套的存储有应用程序的插件库170。插件库170中存储有插件171~174。插件库170由开发人员预先建立,本发明对插件库170中存储的插件数量和种类不做限制,插件库170中存储的插件均承载实现应用程序的一项功能。
运行应用程序的主程序时,创建应用程序的线程池180,所述线程池包括多个线程186~189,适于处理不同插件之间的通信任务。线程池是一种多线程处理形式,处理过程中将任务添加到队列,然后在创建线程后自动启动这些任务。本发明对线程池180中所创建的线程的数量不做限制。图1中所示出的线程池180仅为示例性的包括四个线程。在具体实施本发明的方法300时,可根据应用程序的数据处理需要和计算设备的工况灵活创建所需线程池。
应当指出,在运行应用主程序时,不仅创建线程池180,还执行主程序的其他代码,完成其他步骤以便启动应用程序,本发明对这些步骤不做限制。
随后,从插件库170中选取多个插件,并将每个插件安装到应用程序的主程序。从插件库170中选取插件时,可根据应用程序的运行需要选择所需要的插件进行安装。具体的,可根据主程序中的调用函数和安装函数等从插件库170中选取和安装插件。根据本发明的一个实施例,从插件库170中选取插件171~174安装到应用程序的主程序中,得到如图1所示的安装有插件110~140的主程序180。
如图1所示,计算设备中还配套存储有应用程序的插件数据库150,插件数据库150可实现为SQlite数据库。插件数据库150预先关联的进行建立,在首次将同一插件安装到主程序180时,在插件数据库150中存储插件的配置文件。根据本发明的一个实施例,配置文件可实现为MAINFEST文件。插件库中也存储有插件对应的配置文件,配置文件包括插件名称、插件版权、插件描述、插件版本号、插件激活策略和插件的存储路径等。将每个插件安装到应用程序的主程序时从插件数据库中获取插件的配置文件,此时若从插件数据库中未获取到插件的配置文件,则从插件库中获取对应插件的配置文件并存储到插件数据库,并根据插件的配置文件创建插件的插件启动器。将配置文件存储到插件数据库便于下次加载同样的插件时节约加载时间,直接从插件数据库中调取对应的配置文件。插件启动器用于启动对应的插件已经调用插件注册函数对插件在主程序中进行注册。每个插件对应一个插件启动器,如图1所示,主程序190的插件110~140分别对应有插件启动器161~164。
获取配置文件后,初始化插件上下文,根据配置文件调用对应的插件启动器在主程序中注册服务接口和一个或多个服务事件。服务事件为插件所执行的一项任务,如服务事件可实现为监听事件,对来自用户的操作进行监听。每个插件可以注册一个或多个服务事件,本发明对每个插件所注册的服务事件的数量和种类不做限制。服务事件包括对应的主题名和数据列表,数据列表中关联记载有一项或多项事件数据。服务事件所关联的事件数据以数据列表中所记载的为准,可以通过调整数据表中所记载的事件数据,改变服务事件所关联的事件数据。服务接口为所在插件与其他插件的通信接口,向其他插件发送数据以及接收其他插件发送的数据。
根据本发明的一个实施例,如图1所示,插件启动器161在主程序190中安装插件110,注册有服务事件111~113和服务接口114;插件启动器162在主程序190中安装插件120,注册有服务事件121~123和服务接口124;插件163在主程序190中安装插件130,注册有服务事件131~133和服务接口134;插件164在主程序190中安装插件140,注册有服务事件141~143和服务接口144。
当插件需要将事件数据传输到其他插件时,将事件数据通过服务接口,以通信任务的形式发布至应用程序的线程池,通过线程池处理通信任务将事件数据传输到其他插件。构建通信任务时,根据事件数据对应的服务事件的主题名以及通信数据生成通信任务发布至线程池。
如图1所示的线程池,线程池180中还包括任务队列181。任务队列181暂时存储线程186~189来不及处理的任务。线程186~189处于空闲状态下,线程池180接受到任务时,将任务直接分配给线程186~189进行处理。线程186~189已经有任务正在处理的情况下,线程池180接受到任务时,将任务先暂时寄存在任务队列181中,以便当线程186~189处理完当前任务时,再将任务队列181中的任务分配给线程186~189进行处理。如图1所示的任务队列181,已经存储有未进行分配的任务181~185。
任务181~185可实现为通信任务,本发明对任务181~185的种类不做限制,每项任务均完成一项命令及其数据的处理。插件启动器还设置插件订阅的服务事件。每个插件可订阅一项或多项服务事件,本发明对插件启动器所订阅的服务事件的数量及种类不做限制。当线程池处理通信任务时,确定通信任务的事件数据所对应的服务事件,将事件数据发送至订阅该服务事件的插件。在确定通信任务对应的服务事件时,根据通信任务的主题名确定通信数据对应的服务事件。确定事件数据对应的服务事件后,判断应用程序所注册的插件中订阅该服务事件的插件,将事件数据发送到该插件,以便其对事件数据进行处理。
随后,执行步骤S330,确定主程序中所安装插件中的第一类型插件和第二类型插件,第一类型插件为在应用程序的主界面中运行的插件,第二类型插件为以插件界面形式运行的插件。本发明中将页面插件化,将页面之间的通信转化为插件之间的通信。如图1所示的主程序190,插件110为第一类型插件,在应用程序的主界面中运行,插件120~140为第二类型插件,分别可作为不同的插件界面。
在确定主程序所安装的第一类型插件和第二类型插件后,执行步骤S340,加载第一类型插件,并根据第一类型插件渲染和加载应用程序的主界面。加载第一类型插件时,根据在插件数据库中存储的第一类型插件的配置文件,确定第一类型插件的存储路径,启动第一类型插件。启动第一类型插件时,通过对应的插件启动器调用插件的start函数对插件进行启动。加载完毕第一类型插件,便渲染应用程序的主页面,将主界面呈现给用户,从而缩短打开应用程序的时间,提高用户的使用体验。图4a示出了根据本发明一个示范性实施例的主界面的示意图。
最后,执行步骤S340,加载第二类型插件,以便根据第二类型插件加载对应的插件界面。在渲染完毕主页面后,再加载第二类型插件。加载第二类型插件的方式与加载第一类型插件的方式相同。本发明使主程序只负责插件的安装和启动,并且安装和启动相互分离,以便在不同时机加载第一类型插件和第二类型插件,从而提高应用的启动速度。插件界面与主界面不同时显示,在需要调用插件界面时,再渲染和显示插件界面。图4b示出了根据本发明一个示范性实施例的插件界面的示意图。
根据本发明的一个示范性实施例,图4a所示的主界面向图4b所示的插件界面需要进行通信,则需要预先设置主界面的插件注册有服务事件和服务接口。服务事件为用户触发“主界面发送1”的按钮时,向插件界面发送通信数据。渲染生成插件界面的插件订阅有主页面的插件所注册的服务事件。主界面的插件采用PostEvent异步的方式发送通信数据。并根据通信数据和服务事件对应的主题名生成通信任务发布至线程池。线程池的线程对该通信任务进行处理,将通信数据发送至渲染生成插件界面的插件。插件接受到通信数据后,通过handleEvent函数处理通信数据,最后通过eventSignal信号显示接收到的通信数据:“接受到主界面发送给事件插件的消息!”
根据本发明的一个实施例,运行应用程序的主程序时还在主程序中创建插件框架,以便根据插件框架安装和加载插件。所有插件均安装到插件框架中,便于通过插件框架对插件进行管理,插件的安装,加载以及插件之间的通信均需要通过插件框架进行。在将主程序关闭,退出应用程序时,需要用过插件框架卸载所有插件,以便回收插件资源。在应用程序运行过程中,也可以对插件进行热插拔,安装和卸载插件。当需要关闭插件时,通过插件框架调用析构函数,将所述插件从插件框架进行卸载,以便回收插件资源。
本发明中的应用程序运行方法适于在计算设备中执行,计算设备中存储有插件库,插件库中包括多个插件,每个插件承载一项应用功能。在运行应用程序时,首先运行应用程序的主程序。随后从插件库中选取多个插件,并将每个插件安装到应用程序的主程序,以便实现相应的应用功能。在进行应用的加载时,首先加载第一类型插件,第一类型插件为在应用程序的主界面中运行的插件。接着根据第一类型插件渲染和加载应用程序的主界面,以便实现快速打开应用的主界面,缩短应用的打开时间,提高用户的使用体验。再打开应用程序的主界面后,再加载第二类型插件,以便根据第二类型插件加载对应的插件界面,以实现主界面之外的应用功能。
进一步的,本发明中将页面插件化,将页面之间的通信转化为插件之间的通信。具体的,从插件数据库中获取插件的配置文件,根据配置文件调用对应的插件启动器在主程序中注册服务接口和一个或多个服务事件,服务事件关联有一项或多项事件数据。当插件需要将事件数据传输到其他插件时,将事件数据通过服务接口,以通信任务的形式发布至应用程序的线程池,通过线程池处理通信任务将事件数据传输到其他插件。从而能够减少页面之间的数据相应时间。
在此处所提供的说明书中,说明了大量具体细节。然而,能够理解,本发明的实施例可以在没有这些具体细节的情况下被实践。在一些实例中,并未详细示出公知的方法、结构和技术,以便不模糊对本说明书的理解。
类似地,应当理解,为了精简本公开并帮助理解各个发明方面中的一个或多个,在上面对本发明的示例性实施例的描述中,本发明的各个特征有时被一起分组到单个实施例、图、或者对其的描述中。然而,并不应将该公开的方法解释成反映如下意图:即所要求保护的本发明要求比在每个权利要求中所明确记载的特征更多特征。更确切地说,如下面的权利要求书所反映的那样,发明方面在于少于前面公开的单个实施例的所有特征。因此,遵循具体实施方式的权利要求书由此明确地并入该具体实施方式,其中每个权利要求本身都作为本发明的单独实施例。
本领域那些技术人员应当理解在本文所公开的示例中的设备的模块或单元或组间可以布置在如该实施例中所描述的设备中,或者可替换地可以定位在与该示例中的设备不同的一个或多个设备中。前述示例中的模块可以组合为一个模块或者此外可以分成多个子模块。
本领域那些技术人员可以理解,可以对实施例中的设备中的模块进行自适应性地改变并且把它们设置在与该实施例不同的一个或多个设备中。可以把实施例中的模块或单元或组间组合成一个模块或单元或组间,以及此外可以把它们分成多个子模块或子单元或子组间。除了这样的特征和/或过程或者单元中的至少一些是相互排斥之外,可以采用任何组合对本说明书(包括伴随的权利要求、摘要和附图)中公开的所有特征以及如此公开的任何方法或者设备的所有过程或单元进行组合。除非另外明确陈述,本说明书(包括伴随的权利要求、摘要和附图)中公开的每个特征可以由提供相同、等同或相似目的的替代特征来代替。
此外,本领域的技术人员能够理解,尽管在此所述的一些实施例包括其它实施例中所包括的某些特征而不是其它特征,但是不同实施例的特征的组合意味着处于本发明的范围之内并且形成不同的实施例。例如,在下面的权利要求书中,所要求保护的实施例的任意之一都可以以任意的组合方式来使用。
此外,所述实施例中的一些在此被描述成可以由计算机系统的处理器或者由执行所述功能的其它装置实施的方法或方法元素的组合。因此,具有用于实施所述方法或方法元素的必要指令的处理器形成用于实施该方法或方法元素的装置。此外,装置实施例的在此所述的元素是如下装置的例子:该装置用于实施由为了实施该发明的目的的元素所执行的功能。
这里描述的各种技术可结合硬件或软件,或者它们的组合一起实现。从而,本发明的方法和设备,或者本发明的方法和设备的某些方面或部分可采取嵌入有形媒介,例如软盘、CD-ROM、硬盘驱动器或者其它任意机器可读的存储介质中的程序代码(即指令)的形式,其中当程序被载入诸如计算机之类的机器,并被所述机器执行时,所述机器变成实践本发明的设备。
在程序代码在可编程计算机上执行的情况下,计算设备一般包括处理器、处理器可读的存储介质(包括易失性和非易失性存储器和/或存储元件),至少一个输入装置,和至少一个输出装置。其中,存储器被配置用于存储程序代码;处理器被配置用于根据该存储器中存储的所述程序代码中的指令,执行本发明的设备停机状态的判断方法。
以示例而非限制的方式,计算机可读介质包括计算机存储介质和通信介质。计算机可读介质包括计算机存储介质和通信介质。计算机存储介质存储诸如计算机可读指令、数据结构、程序模块或其它数据等信息。通信介质一般以诸如载波或其它传输机制等已调制数据信号来体现计算机可读指令、数据结构、程序模块或其它数据,并且包括任何信息传递介质。以上的任一种的组合也包括在计算机可读介质的范围之内。
如在此所使用的那样,除非另行规定,使用序数词“第一”、“第二”、“第三”等等来描述普通对象仅仅表示涉及类似对象的不同实例,并且并不意图暗示这样被描述的对象必须具有时间上、空间上、排序方面或者以任意其它方式的给定顺序。
尽管根据有限数量的实施例描述了本发明,但是受益于上面的描述,本技术领域内的技术人员明白,在由此描述的本发明的范围内,可以设想其它实施例。此外,应当注意,本说明书中使用的语言主要是为了可读性和教导的目的而选择的,而不是为了解释或者限定本发明的主题而选择的。因此,在不偏离所附权利要求书的范围和精神的情况下,对于本技术领域的普通技术人员来说许多修改和变更都是显而易见的。对于本发明的范围,对本发明所做的公开是说明性的,而非限制性的,本发明的范围由所附权利要求书限定。

Claims (10)

1.一种应用程序运行方法,适于在计算设备中执行,所述计算设备中存储有插件库,插件库中包括多个插件,所述方法包括步骤:
运行所述应用程序的主程序;
从所述插件库中选取多个插件,并将每个插件安装到所述应用程序的主程序;
确定所述主程序中所安装插件中的第一类型插件和第二类型插件,所述第一类型插件为在所述应用程序的主界面中运行的插件,所述第二类型插件为以插件界面形式运行的插件;
加载所述第一类型插件,并根据第一类型插件渲染和加载所述应用程序的主界面;
加载所述第二类型插件,以便根据第二类型插件加载对应的插件界面。
2.如权利要求1所述的方法,其中,所述运行所述应用程序的主程序包括步骤:
创建所述应用程序的线程池,所述线程池包括多个线程,适于处理不同插件之间的通信任务。
3.如权利要求2所述的方法,其中,所述计算设备中还存储有插件数据库,所述插件数据库适于存储和查询插件的配置文件,所述将每个插件安装到所述应用程序的主程序包括步骤:
从所述插件数据库中获取所述插件的配置文件;
根据所述配置文件调用对应的插件启动器在所述主程序中注册服务接口和一个或多个服务事件,所述服务事件关联有一项或多项事件数据;
当所述插件需要将事件数据传输到其他插件时,将所述事件数据通过所述服务接口,以通信任务的形式发布至所述应用程序的线程池,通过所述线程池处理所述通信任务将事件数据传输到其他插件。
4.如权利要求3所述的方法,还包括步骤:
通过所述插件启动器设置所述插件订阅的服务事件;
当所述线程池处理所述通信任务时,确定所述通信任务的事件数据所对应的服务事件,将所述事件数据发送至订阅该服务事件的插件。
5.如权利要求4所述的方法,其中,所述服务事件包括对应的主题名,所述将所述事件数据通过所述服务接口,以通信任务的形式发布至所述应用程序的线程池包括步骤:
根据所述事件数据对应的服务事件的主题名以及通信数据生成通信任务发布至线程池;
所述线程池处理所述通信任务时,确定所述通信任务的事件数据所对应的服务事件包括步骤:
根据所述通信任务的主题名确定通信数据对应的服务事件。
6.如权利要求3-5中任一项所述的方法,还包括步骤:
若从所述插件数据库中未获取到插件的配置文件,则从所述插件库中获取对应插件的配置文件并存储到所述插件数据库;
根据所述插件的配置文件创建插件的插件启动器。
7.如权利要求3-5中任一项所述的方法,其中,所述加载所述第一类型插件包括步骤:
根据在所述插件数据库中存储的所述第一类型插件的配置文件,确定所述第一类型插件的存储路径,启动所述第一类型插件。
8.如权利要求1-5中任一项所述的方法,其中,所述运行所述应用程序的主程序还包括步骤:
在所述主程序中创建插件框架,以便根据所述插件框架安装和加载插件;
当需要关闭插件时,通过所述插件框架调用析构函数,将所述插件从所述插件框架进行卸载,以便回收插件资源。
9.一种计算设备,包括:
一个或多个处理器;
存储器;以及
一个或多个装置,所述一个或多个装置包括用于执行根据权利要求1至8所述的方法中的任一方法的指令。
10.一种存储一个或多个程序的计算机可读存储介质,所述一个或多个程序包括指令,所述指令当由计算设备执行时,使得所述计算设备执行根据权利要求1至8所述的方法中的任一方法。
CN202110836043.3A 2021-07-23 2021-07-23 一种应用程序运行方法、计算设备及存储介质 Active CN113485769B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202110836043.3A CN113485769B (zh) 2021-07-23 2021-07-23 一种应用程序运行方法、计算设备及存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202110836043.3A CN113485769B (zh) 2021-07-23 2021-07-23 一种应用程序运行方法、计算设备及存储介质

Publications (2)

Publication Number Publication Date
CN113485769A CN113485769A (zh) 2021-10-08
CN113485769B true CN113485769B (zh) 2024-05-14

Family

ID=77943227

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202110836043.3A Active CN113485769B (zh) 2021-07-23 2021-07-23 一种应用程序运行方法、计算设备及存储介质

Country Status (1)

Country Link
CN (1) CN113485769B (zh)

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103176795A (zh) * 2013-02-04 2013-06-26 中国电子科技集团公司第二十八研究所 一种基于插件技术在信息分发软件数据过滤中的应用方法
CN103425468A (zh) * 2012-05-17 2013-12-04 航天信息股份有限公司 插件式软件集成方法及装置
CN106681718A (zh) * 2016-12-16 2017-05-17 武汉中地数码科技有限公司 一种基于工具集的桌面端插件框架及实现方法
CN107911401A (zh) * 2017-08-04 2018-04-13 上海壹账通金融科技有限公司 应用插件扩展功能方法及应用服务器
CN110851193A (zh) * 2018-08-01 2020-02-28 深圳市理邦精密仪器股份有限公司 监护设备软件平台插件加载方法、插件运行系统及监护仪
CN112818266A (zh) * 2019-10-31 2021-05-18 北京国双科技有限公司 渲染方法、装置、存储介质及电子设备

Family Cites Families (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8706801B2 (en) * 2009-07-20 2014-04-22 Facebook, Inc. Rendering a web page using content communicated to a browser application from a process running on a client
CN105912366B (zh) * 2016-04-14 2019-07-05 广州久邦世纪科技有限公司 一种桌面应用程序插件化的实现方法
CN107870787B (zh) * 2016-09-26 2021-04-27 平安科技(深圳)有限公司 应用程序插件化加载方法及系统
CN108491236A (zh) * 2018-03-23 2018-09-04 努比亚技术有限公司 一种插件加载方法、装置及计算机可读存储介质

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103425468A (zh) * 2012-05-17 2013-12-04 航天信息股份有限公司 插件式软件集成方法及装置
CN103176795A (zh) * 2013-02-04 2013-06-26 中国电子科技集团公司第二十八研究所 一种基于插件技术在信息分发软件数据过滤中的应用方法
CN106681718A (zh) * 2016-12-16 2017-05-17 武汉中地数码科技有限公司 一种基于工具集的桌面端插件框架及实现方法
CN107911401A (zh) * 2017-08-04 2018-04-13 上海壹账通金融科技有限公司 应用插件扩展功能方法及应用服务器
CN110851193A (zh) * 2018-08-01 2020-02-28 深圳市理邦精密仪器股份有限公司 监护设备软件平台插件加载方法、插件运行系统及监护仪
CN112818266A (zh) * 2019-10-31 2021-05-18 北京国双科技有限公司 渲染方法、装置、存储介质及电子设备

Also Published As

Publication number Publication date
CN113485769A (zh) 2021-10-08

Similar Documents

Publication Publication Date Title
CN113434205B (zh) 一种操作系统启动方法及计算设备
CN112000417B (zh) 一种窗口展示效果的控制方法及计算设备
CN114691226A (zh) 一种多操作系统切换运行方法、计算设备及存储介质
CN114968373A (zh) 指令分派方法、装置、电子设备及计算机可读存储介质
CN113485769B (zh) 一种应用程序运行方法、计算设备及存储介质
US10127047B2 (en) Operation of a multi-slice processor with selective producer instruction types
CN111930392B (zh) 一种应用服务部署方法、计算设备及可读存储介质
US10523508B2 (en) Monitoring management systems and methods
CN114003289A (zh) 一种应用程序运行方法、计算设备及存储介质
CN113204385A (zh) 一种插件加载方法、装置、计算设备及可读存储介质
US20120144390A1 (en) Customized computer image preparation and deployment including virtual machine mode
CN113961086B (zh) 一种快捷键实现方法、计算设备及存储介质
CN114721672A (zh) 一种应用安装方法、计算设备及存储介质
WO2022222351A1 (zh) 一种操作系统安装方法及计算设备
CN108196868A (zh) Bios升级方法和电子设备
CN115390801A (zh) 一种开放式图形库渲染的开启方法、装置与计算设备
WO2022140043A1 (en) Condensed command packet for high throughput and low overhead kernel launch
CN113867825B (zh) 一种多系统运行方法、计算设备及存储介质
CN113138806B (zh) 一种移动应用运行环境的处理方法及装置
CN113535650B (zh) 一种文件命名方法及计算设备
CN111913814B (zh) 对象拷贝方法及计算设备
US11886883B2 (en) Dependency skipping in a load-compare-jump sequence of instructions by incorporating compare functionality into the jump instruction and auto-finishing the compare instruction
CN113835927B (zh) 一种指令执行方法、计算设备及存储介质
CN115033363A (zh) 一种计算任务调度方法、系统、计算设备及存储介质
CN114217904A (zh) 一种多版本应用运行方法、计算设备及存储介质

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
GR01 Patent grant
GR01 Patent grant