CN114510288B - 一种跨进程插件实现方法、计算设备及存储介质 - Google Patents
一种跨进程插件实现方法、计算设备及存储介质 Download PDFInfo
- Publication number
- CN114510288B CN114510288B CN202210094117.5A CN202210094117A CN114510288B CN 114510288 B CN114510288 B CN 114510288B CN 202210094117 A CN202210094117 A CN 202210094117A CN 114510288 B CN114510288 B CN 114510288B
- Authority
- CN
- China
- Prior art keywords
- plug
- frame data
- interface
- display content
- new
- 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
Links
- 238000000034 method Methods 0.000 title claims abstract description 250
- 230000008569 process Effects 0.000 claims abstract description 171
- 230000000694 effects Effects 0.000 claims description 3
- 238000012795 verification Methods 0.000 claims description 2
- 230000002159 abnormal effect Effects 0.000 abstract description 4
- 238000004891 communication Methods 0.000 description 21
- 230000006870 function Effects 0.000 description 5
- 238000010586 diagram Methods 0.000 description 4
- 238000012545 processing Methods 0.000 description 4
- 230000008901 benefit Effects 0.000 description 3
- 235000014510 cooky Nutrition 0.000 description 3
- 238000011161 development Methods 0.000 description 3
- 230000002093 peripheral effect Effects 0.000 description 3
- 230000009286 beneficial effect Effects 0.000 description 2
- 230000007723 transport mechanism Effects 0.000 description 2
- 230000005856 abnormality Effects 0.000 description 1
- 230000001413 cellular effect Effects 0.000 description 1
- 238000010276 construction Methods 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 238000007667 floating Methods 0.000 description 1
- 238000004519 manufacturing process Methods 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/44—Arrangements for executing specific programs
- G06F9/445—Program loading or initiating
- G06F9/44521—Dynamic linking or loading; Link editing at or after load time, e.g. Java class loading
- G06F9/44526—Plug-ins; Add-ons
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/46—Multiprogramming arrangements
- G06F9/48—Program initiating; Program switching, e.g. by interrupt
- G06F9/4806—Task transfer initiation or dispatching
- G06F9/4843—Task transfer initiation or dispatching by program, e.g. task dispatcher, supervisor, operating system
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
- Stored Programmes (AREA)
Abstract
本发明公开了一种跨进程插件实现方法、计算设备及存储介质,方法在计算设备的主进程中执行,所述主进程提供有内容同步接口,所述方法包括步骤:接收插件进程通过调用所述内容同步接口发送的当前帧数据;将所述当前帧数据与上一帧数据进行对比,以确定所述当前帧数据是否为差异帧数据;如果是差异帧数据,则基于所述差异帧数据与上一帧数据生成新的完整帧数据;以及对所述新的完整帧数据进行解析,以生成新的插件显示内容并进行显示。根据本发明的技术方案,能够避免插件异常时而导致应用主进程崩溃退出的问题。
Description
技术领域
本发明涉及计算机技术领域,特别涉及一种跨进程插件实现方法、计算设备及存储介质。
背景技术
随着软件技术的发展以及人们对软件可拓展性越来越高的要求,大多数软件在发布后,开发者后续会在程序主体的基础上开发出丰富的第三方插件,以便基于第三方插件提供丰富多样化的功能。
现有技术中,基于插件扩展应用功能最常见的方案是采用加载动态库的形式。由于动态库会被加载到程序的内存空间,一旦动态库内部出现错误,例如野指针、数组越界等行为,很容易导致宿主程序崩溃退出。这对于对稳定性要求较高的操作系统桌面环境而言,会造成严重的生产事故。
可见,采用加载动态库的方案,当第三方插件的内容在宿主程序的界面上显示时,容易因第三方插件的异常而导致宿主程序崩溃退出的问题。
为此,需要一种跨进程插件实现方法,以解决上述技术方案中存在的问题。
发明内容
为此,本发明提供一种跨进程插件实现方法,以力图解决或者至少缓解上面存在的问题。
根据本发明的一个方面,提供了一种跨进程插件实现方法,在计算设备的主进程中执行,所述主进程提供有内容同步接口,所述方法包括步骤:接收插件进程通过调用所述内容同步接口发送的当前帧数据;将所述当前帧数据与上一帧数据进行对比,以确定所述当前帧数据是否为差异帧数据;如果是差异帧数据,则基于所述差异帧数据与上一帧数据生成新的完整帧数据;以及对所述新的完整帧数据进行解析,以生成新的插件显示内容并进行显示。
可选地,在根据本发明的跨进程插件实现方法中,所述方法还包括步骤:如果当前帧数据不是差异帧数据,则将所述当前帧数据作为新的完整帧数据。
可选地,在根据本发明的跨进程插件实现方法中,所述主进程的界面上适于显示与插件相对应的插件界面,在接收插件进程通过调用所述内容同步接口发送的当前帧数据之前,包括步骤:检测在所述插件界面上的用户操作,根据用户操作判断是否需要对插件界面上的当前插件显示内容进行更新;如果是,则向所述插件进程发送更新插件显示内容的信号,以便插件进程在接收到所述信号后调用所述内容同步接口向主进程发送当前帧数据。
可选地,在根据本发明的跨进程插件实现方法中,所述完整帧数据为xml格式;对所述新的完整帧数据进行解析,以生成新的插件显示内容并进行显示的步骤包括:基于所述新的完整帧数据中的节点顺序,依次绘制每个节点对应的控件,以生成层叠效果的插件显示内容并显示在插件界面上。
可选地,在根据本发明的跨进程插件实现方法中,所述主进程提供有插件注册接口,在接收插件进程通过调用所述内容同步接口发送的当前帧数据之前,还包括步骤:接收插件进程通过调用所述插件注册接口发送的插件注册请求;检测所述插件进程是否是黑名单进程,如果否,检测所述插件进程是否已经注册;如果所述插件进程未注册,则向插件进程返回对应的身份识别码,以便插件进程在向主进程发送帧数据时基于所述身份识别码进行身份认证。
可选地,在根据本发明的跨进程插件实现方法中,还包括步骤:如果所述插件进程是黑名单进程或者已经注册,则拒绝插件进程注册。
可选地,在根据本发明的跨进程插件实现方法中,接收插件进程通过调用所述内容同步接口发送的当前帧数据的步骤包括:接收插件进程通过调用所述内容同步接口发送的当前帧数据以及所述身份识别码;基于所述身份识别码对所述插件进程进行身份认证,并在验证通过后获取所述当前帧数据。
可选地,在根据本发明的跨进程插件实现方法中,所述主进程与插件进程适于基于DBus进行通信。
根据本发明的一个方面,提供了一种计算设备,包括:至少一个处理器;以及存储器,存储有程序指令,其中,所述程序指令被配置为适于由所述至少一个处理器执行,所述程序指令包括用于执行如上所述的跨进程插件实现方法的指令。
根据本发明的一个方面,提供了一种存储有程序指令的可读存储介质,当所述程序指令被计算设备读取并执行时,使得所述计算设备执行如上所述方法。
根据本发明的技术方案,提供了一种跨进程插件实现方法,应用的主进程与插件进程分属不同的进程。应用的主进程提供有插件注册接口、内容同步接口,以供插件进程调用接口。其中,插件进程通过调用内容同步接口向主进程发送差异帧数据,以向主进程同步待更新的插件显示内容对应的数据,主进程基于差异帧数据和上一帧数据合并为新的完整帧数据,并基于新的完整帧数据绘制新的插件显示内容进行显示。这样,不仅能够避免插件异常时而导致应用主进程崩溃退出的问题,而且,插件进程在调用内容同步接口向主进程进行数据同步时,通过发送差异帧数据,有利于提高插件进程与主进程之间的数据同步效率,从而提高对插件显示内容的更新速度。此外,通过主进程来绘制插件显示内容,能够保证插件界面与应用界面的整体风格的统一。
上述说明仅是本发明技术方案的概述,为了能够更清楚了解本发明的技术手段,而可依照说明书的内容予以实施,并且为了让本发明的上述和其它目的、特征和优点能够更明显易懂,以下特举本发明的具体实施方式。
附图说明
为了实现上述以及相关目的,本文结合下面的描述和附图来描述某些说明性方面,这些方面指示了可以实践本文所公开的原理的各种方式,并且所有方面及其等效方面旨在落入所要求保护的主题的范围内。通过结合附图阅读下面的详细描述,本公开的上述以及其它目的、特征和优势将变得更加明显。遍及本公开,相同的附图标记通常指代相同的部件或元素。
图1示出了根据本发明一个实施例的计算设备100的示意图;以及
图2示出了根据本发明一个实施例的跨进程插件实现方法200的流程图。
具体实施方式
下面将参照附图更详细地描述本公开的示例性实施例。虽然附图中显示了本公开的示例性实施例,然而应当理解,可以以各种形式实现本公开而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本公开,并且能够将本公开的范围完整的传达给本领域的技术人员。
图1是示例计算设备100的示意框图。
如图1所示,在基本的配置102中,计算设备100典型地包括系统存储器106和一个或者多个处理器104。存储器总线108可以用于在处理器104和系统存储器106之间的通信。
取决于期望的配置,处理器104可以是任何类型的处理,包括但不限于:微处理器(UP)、微控制器(UC)、数字信息处理器(DSP)或者它们的任何组合。处理器104可以包括诸如一级高速缓存110和二级高速缓存112之类的一个或者多个级别的高速缓存、处理器核心114和寄存器116。示例的处理器核心114可以包括运算逻辑单元(ALU)、浮点数单元(FPU)、数字信号处理核心(DSP核心)或者它们的任何组合。示例的存储器控制器118可以与处理器104一起使用,或者在一些实现中,存储器控制器118可以是处理器104的一个内部部分。
取决于期望的配置,系统存储器106可以是任意类型的存储器,包括但不限于:易失性存储器(诸如RAM)、非易失性存储器(诸如ROM、闪存等)或者它们的任何组合。系统存储器106可以包括操作系统120、一个或者多个应用122以及程序数据124。在一些实施方式中,应用122可以布置为在操作系统上由一个或多个处理器104利用程序数据124执行指令。
计算设备100还包括储存设备132,储存设备132包括可移除储存器136和不可移除储存器138。
计算设备100还可以包括储存接口总线134。储存接口总线134实现了从储存设备132(例如,可移除储存器136和不可移除储存器138)经由总线/接口控制器130到基本配置102的通信。操作系统120、应用122以及数据124的至少一部分可以存储在可移除储存器136和/或不可移除储存器138上,并且在计算设备100上电或者要执行应用122时,经由储存接口总线134而加载到系统存储器106中,并由一个或者多个处理器104来执行。
计算设备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可以实现为包括桌面计算机和笔记本计算机配置的个人计算机。当然,计算设备100也可以实现为小尺寸便携(或者移动)电子设备的一部分,这些电子设备可以是诸如蜂窝电话、数码照相机、个人数字助理(PDA)、个人媒体播放器设备、无线网络浏览设备、个人头戴设备、应用专用设备、或者可以包括上面任何功能的混合设备。甚至可以被实现为服务器,如文件服务器、数据库服务器、应用程序服务器和WEB服务器等。本发明的实施例对此均不做限制。
在根据本发明的实施例中,计算设备100被配置为执行根据本发明的跨进程插件实现方法200。其中,计算设备100的应用中包含用于执行本发明的跨进程插件实现方法200的多条程序指令,使得本发明的跨进程插件实现方法200可以在计算设备100中执行。
图2示出了根据本发明一个实施例的跨进程插件实现方法200的流程图。跨进程插件实现方法200可以在计算设备(例如前述计算设备100)的应用的主进程中执行。
需要说明的是,在本发明的实施例中,应用的主进程与插件进程分属不同的进程。应用的主进程提供有插件注册接口、内容同步接口,以供插件进程调用接口,其中,插件进程通过调用内容同步接口可以实现向主进程同步插件显示内容数据。这样,能够避免插件异常时而导致应用主进程崩溃退出的问题。
如图2所示,方法200始于步骤S210。
在步骤S210中,接收插件进程通过调用内容同步接口发送的当前帧数据。
这里,插件显示的内容由插件所在进程(插件进程)控制,当插件进程确定需要更新插件显示内容时,通过调用主进程提供的内容同步接口来向主进程发送与待更新的插件显示内容相对应的帧数据,以实现将需要显示的新的插件显示内容实时同步至主进程。
在一个实施例中,插件包括相应的插件界面,主进程的界面(应用界面)上可以显示与插件相对应的插件界面。在执行步骤S210之前,主进程检测在插件界面上的用户操作,根据用户操作来判断是否需要对插件界面上的当前插件显示内容进行更新。如果确定需要对插件界面上的当前插件显示内容进行更新,则主进程向插件进程发送更新插件显示内容的信号。插件进程在接收到更新插件显示内容的信号后,调用内容同步接口向主进程同步发送待更新的插件显示内容(需要修改的插件内容)对应的当前帧数据。
需要说明的是,插件进程每次调用内容同步接口Sync同步向主进程发送一帧数据。
随后,在步骤S220中,将当前帧数据与上一帧数据进行对比,以确定当前帧数据是否为差异帧数据。这里,差异帧数据只包含待更新的插件显示内容对应的完整帧数据与上一帧数据之间的差异数据。
在一个实施例中,可以根据当前帧数据中的预定字段来确定当前帧数据是否是差异帧数据。这里,预定字段中包含是否是差异帧的相关信息。具体地,在确定帧数据的数据结构后,可以使用数据结构中的一个字段(预定字段)来描述是否是差异帧的相关信息,以表示帧数据是否是差异帧。
在步骤S230中,如果确定当前帧数据是差异帧数据,则基于差异帧数据与上一帧数据组合生成新的完整帧数据。具体地,基于差异帧数据来对上一帧数据进行修改和更新,可以得到新的完整帧数据。
另外,如果当前帧数据不是差异帧数据(即,当前帧数据是完整帧数据),则直接将当前帧数据作为新的完整帧数据。
需要说明的是,插件进程调用内容同步接口优先发送的是与待更新的插件显示内容相对应的差异帧数据,在发送差异帧数据失败后,再次调用内容同步接口发送完整帧数据。
可以理解,插件进程在调用内容同步接口向主进程进行数据同步时,通过发送差异帧数据,只传输新的完整帧数据与上一帧数据之间的差异数据,这样有利于提高插件进程与主进程之间的数据同步效率,进而提高对插件显示内容的更新速度。
最后,在步骤S240中,主进程对新的完整帧数据进行解析,以生成新的插件显示内容并进行显示。
这里,主进程基于新的完整帧数据可以绘制生成新的插件显示内容,并将新的插件显示内容显示在主进程的界面上,以替换原有的插件显示内容,从而实现对插件显示内容的更新。
需要说明的是,由主进程绘制插件显示内容,能够保证插件界面与应用主程序界面的整体风格的统一。
根据本发明的一个实施例,完整帧数据的格式为xml格式,其中包括多个数据节点,每个节点分别可对应一个控件。控件例如包括文本控件、按钮控件、表格控件等。
在步骤S240中对新的完整帧数据进行解析生成新的插件显示内容的过程中,是基于新的完整帧数据中的节点顺序,依次解析并绘制每个节点对应的控件(对控件初始化),以便最终生成层叠效果的插件显示内容,并将插件显示内容显示在插件界面上。这里,最终呈现在插件界面上的插件显示内容包括多个具有层叠结构的控件。
在一种实现方式中,分别利用与控件相对应的版本的解析器来解析节点的标签下包含的一种或多种属性,基于一种或多种属性信息来绘制节点对应的控件。属性信息例如包括控件的坐标、宽度、高度、颜色、样式等信息。
根据本发明的一个实施例,在接收插件进程通过调用内容同步接口发送的当前帧数据之前,插件进程首先调用主进程提供的插件注册接口来进行插件服务的注册。其中,主进程具体执行以下步骤:
接收插件进程通过调用插件注册接口发送的插件注册请求。
检测插件进程是否是黑名单进程,如果是黑名单进程,则拒绝插件进程注册并向插件进程返回注册失败的结果。如果不是黑名单进程,则进一步检测插件进程是否已经注册。
如果插件进程未注册,则向插件进程返回注册成功的结果,并向插件进程返回对应的身份识别码(Cookie),以便插件进程在向主进程发送帧数据时基于身份识别码进行身份认证。这里,主进程通过获取插件进程标识(PID),将插件进程标识对应的身份识别码(Cookie)返回至插件进程。需要说明的是,插件进程在调用主进程的插件注册接口获取到身份识别码后,后续可以基于身份识别码与主进程进行通信,以便向主进程同步发送数据。具体地,插件进程可以调用内容同步接口来将当前帧数据和身份识别码发送至主进程,主进程首先基于身份识别码来对插件进程进行身份认证。
如果检测到插件进程已经注册过插件服务,则拒绝插件进程注册,并向插件进程返回注册失败的结果,以避免同一个插件进程反复注册插件服务。
可见,本发明通过在插件进程注册插件服务时对插件进程进行检测,当检测到插件进程是黑名单进程或者插件进程已经注册时,拒绝插件进程注册。插件进程在注册失败后不能与主进程进行后续的通信,即,不能执行实现插件显示内容同步的相关步骤,不能向主进程发送当前帧数据来进行插件显示内容的同步。
在一个实施例中,在步骤S210中,接收插件进程通过调用内容同步接口发送的当前帧数据的具体步骤如下:
接收插件进程通过调用内容同步接口发送的当前帧数据、以及身份识别码。这里,身份识别码是插件进程预先调用插件注册接口获取到的与插件进程的PID相对应的Cookie。
随后基于身份识别码对插件进程进行身份认证,并在验证通过后获取当前帧数据。
在一种实现方式中,主进程与插件进程在进行通信之前,需要分别连接到DBus总线,以便主进程与插件进程基于DBus总线进行通信。主进程基于DBus总线来向插件进程提供内容同步接口Sync和插件注册接口Register,以供插件进程调用。这样,由于DBus采用二进制的协议,插件进程与主进程之间的通信只需要通过DBus传输纯文本数据即可,通信效率高,而且不限于开发语言,从而降低了对插件的开发成本,并且支持跨平台,扩展性强。
根据本发明的跨进程插件实现方法,应用的主进程与插件进程分属不同的进程,应用的主进程向插件进程提供有插件注册接口、内容同步接口,其中,插件进程通过调用内容同步接口向主进程发送差异帧数据,以向主进程同步待更新的插件显示内容对应的数据,主进程基于差异帧数据和上一帧数据合并为新的完整帧数据,并基于新的完整帧数据绘制新的插件显示内容进行显示。这样,不仅能够避免插件异常时而导致应用主进程崩溃退出的问题,而且,插件进程在调用内容同步接口向主进程进行数据同步时,通过发送差异帧数据,有利于提高插件进程与主进程之间的数据同步效率,从而提高对插件显示内容的更新速度。此外,通过主进程来绘制插件显示内容,能够保证插件界面与应用主界面的整体风格的统一。
这里描述的各种技术可结合硬件或软件,或者它们的组合一起实现。从而,本发明的方法和设备,或者本发明的方法和设备的某些方面或部分可采取嵌入有形媒介,例如可移动硬盘、U盘、软盘、CD-ROM或者其它任意机器可读的存储介质中的程序代码(即指令)的形式,其中当程序被载入诸如计算机之类的机器,并被所述机器执行时,所述机器变成实践本发明的设备。
在程序代码在可编程计算机上执行的情况下,计算设备一般包括处理器、处理器可读的存储介质(包括易失性和非易失性存储器和/或存储元件),至少一个输入装置,和至少一个输出装置。其中,存储器被配置用于存储程序代码;处理器被配置用于根据该存储器中存储的所述程序代码中的指令,执行本发明的跨进程插件实现方法。
以示例而非限制的方式,可读介质包括可读存储介质和通信介质。可读存储介质存储诸如计算机可读指令、数据结构、程序模块或其它数据等信息。通信介质一般以诸如载波或其它传输机制等已调制数据信号来体现计算机可读指令、数据结构、程序模块或其它数据,并且包括任何信息传递介质。以上的任一种的组合也包括在可读介质的范围之内。
在此处所提供的说明书中,算法和显示不与任何特定计算机、虚拟系统或者其它设备固有相关。各种通用系统也可以与本发明的示例一起使用。根据上面的描述,构造这类系统所要求的结构是显而易见的。此外,本发明也不针对任何特定编程语言。应当明白,可以利用各种编程语言实现在此描述的本发明的内容,并且上面对特定语言所做的描述是为了披露本发明的最佳实施方式。
在此处所提供的说明书中,说明了大量具体细节。然而,能够理解,本发明的实施例可以在没有这些具体细节的情况下被实践。在一些实例中,并未详细示出公知的方法、结构和技术,以便不模糊对本说明书的理解。
类似地,应当理解,为了精简本公开并帮助理解各个发明方面中的一个或多个,在上面对本发明的示例性实施例的描述中,本发明的各个特征有时被一起分组到单个实施例、图、或者对其的描述中。然而,并不应将该公开的方法解释成反映如下意图:即所要求保护的本发明要求比在每个权利要求中所明确记载的特征更多特征。因此,遵循具体实施方式的权利要求书由此明确地并入该具体实施方式,其中每个权利要求本身都作为本发明的单独实施例。
本领域那些技术人员应当理解在本文所公开的示例中的设备的模块或单元或组件可以布置在如该实施例中所描述的设备中,或者可替换地可以定位在与该示例中的设备不同的一个或多个设备中。前述示例中的模块可以组合为一个模块或者此外可以分成多个子模块。
本领域那些技术人员可以理解,可以对实施例中的设备中的模块进行自适应性地改变并且把它们设置在与该实施例不同的一个或多个设备中。可以把实施例中的模块或单元或组件组合成一个模块或单元或组件,以及此外可以把它们分成多个子模块或子单元或子组件。除了这样的特征和/或过程或者单元中的至少一些是相互排斥之外,可以采用任何组合对本说明书(包括伴随的权利要求、摘要和附图)中公开的所有特征以及如此公开的任何方法或者设备的所有过程或单元进行组合。除非另外明确陈述,本说明书(包括伴随的权利要求、摘要和附图)中公开的每个特征可以由提供相同、等同或相似目的的替代特征来代替。
此外,本领域的技术人员能够理解,尽管在此所述的一些实施例包括其它实施例中所包括的某些特征而不是其它特征,但是不同实施例的特征的组合意味着处于本发明的范围之内并且形成不同的实施例。
此外,所述实施例中的一些在此被描述成可以由计算机系统的处理器或者由执行所述功能的其它装置实施的方法或方法元素的组合。因此,具有用于实施所述方法或方法元素的必要指令的处理器形成用于实施该方法或方法元素的装置。此外,装置实施例的在此所述的元素是如下装置的例子:该装置用于实施由为了实施该发明的目的的元素所执行的功能。
如在此所使用的那样,除非另行规定,使用序数词“第一”、“第二”、“第三”等等来描述普通对象仅仅表示涉及类似对象的不同实例,并且并不意图暗示这样被描述的对象必须具有时间上、空间上、排序方面或者以任意其它方式的给定顺序。
尽管根据有限数量的实施例描述了本发明,但是受益于上面的描述,本技术领域内的技术人员明白,在由此描述的本发明的范围内,可以设想其它实施例。此外,应当注意,本说明书中使用的语言主要是为了可读性和教导的目的而选择的,而不是为了解释或者限定本发明的主题而选择的。因此,在不偏离所附权利要求书的范围和精神的情况下,对于本技术领域的普通技术人员来说许多修改和变更都是显而易见的。对于本发明的范围,对本发明所做的公开是说明性的,而非限制性的,本发明的范围由所附权利要求书限定。
Claims (7)
1.一种跨进程插件实现方法,在计算设备的主进程中执行,所述主进程提供有内容同步接口和插件注册接口,且所述主进程的界面上适于显示与插件相对应的插件界面,所述方法包括步骤:
接收插件进程通过调用所述插件注册接口发送的插件注册请求;
检测所述插件进程是否是黑名单进程,如果否,检测所述插件进程是否已经注册;
如果所述插件进程未注册,则向插件进程返回对应的身份识别码,以便插件进程在向主进程发送帧数据时基于所述身份识别码进行身份认证;
检测在所述插件界面上的用户操作,根据用户操作判断是否需要对插件界面上的当前插件显示内容进行更新,如果是,则向所述插件进程发送更新插件显示内容的信号;
接收插件进程在接收到所述信号后通过调用所述内容同步接口发送的当前帧数据以及所述身份识别码,基于所述身份识别码对所述插件进程进行身份认证,并在验证通过后获取所述当前帧数据;
根据当前帧数据中的预定字段来确定所述当前帧数据是否为差异帧数据;
如果是差异帧数据,则基于所述差异帧数据与上一帧数据生成新的完整帧数据;
对所述新的完整帧数据进行解析,以生成新的插件显示内容并进行显示;
其中,所述插件进程调用所述内容同步接口首先发送的是与待更新的插件显示内容相对应的差异帧数据,在发送差异帧数据失败后,再次调用内容同步接口发送完整帧数据。
2.如权利要求1所述的方法,其中,所述方法还包括步骤:
如果当前帧数据不是差异帧数据,则将所述当前帧数据作为新的完整帧数据。
3.如权利要求1或2所述的方法,其中,所述完整帧数据为xml格式;对所述新的完整帧数据进行解析,以生成新的插件显示内容并进行显示的步骤包括:
基于所述新的完整帧数据中的节点顺序,依次绘制每个节点对应的控件,以生成层叠效果的插件显示内容并显示在插件界面上。
4.如权利要求1或2所述的方法,其中,还包括步骤:
如果所述插件进程是黑名单进程或者已经注册,则拒绝插件进程注册。
5.如权利要求1或2所述的方法,其中,
所述主进程与插件进程适于基于DBus进行通信。
6.一种计算设备,包括:
至少一个处理器;以及
存储器,存储有程序指令,其中,所述程序指令被配置为适于由所述至少一个处理器执行,所述程序指令包括用于执行如权利要求1-5中任一项所述的方法的指令。
7.一种存储有程序指令的可读存储介质,当所述程序指令被计算设备读取并执行时,使得所述计算设备执行如权利要求1-5中任一项所述方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210094117.5A CN114510288B (zh) | 2022-01-26 | 2022-01-26 | 一种跨进程插件实现方法、计算设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210094117.5A CN114510288B (zh) | 2022-01-26 | 2022-01-26 | 一种跨进程插件实现方法、计算设备及存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN114510288A CN114510288A (zh) | 2022-05-17 |
CN114510288B true CN114510288B (zh) | 2024-06-04 |
Family
ID=81550729
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202210094117.5A Active CN114510288B (zh) | 2022-01-26 | 2022-01-26 | 一种跨进程插件实现方法、计算设备及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN114510288B (zh) |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103618662A (zh) * | 2013-11-22 | 2014-03-05 | 奇智软件(北京)有限公司 | 一种实现即时通讯的方法和装置 |
WO2017023332A1 (en) * | 2015-08-06 | 2017-02-09 | Hewlett Packard Enterprise Development Lp | Difference datasets |
US9614900B1 (en) * | 2014-06-19 | 2017-04-04 | Amazon Technologies, Inc. | Multi-process architecture for a split browser |
CN107145529A (zh) * | 2017-04-17 | 2017-09-08 | 东软集团股份有限公司 | 一种数据处理方法及装置 |
CN107463370A (zh) * | 2017-06-30 | 2017-12-12 | 百度在线网络技术(北京)有限公司 | 跨进程渲染方法及系统 |
-
2022
- 2022-01-26 CN CN202210094117.5A patent/CN114510288B/zh active Active
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103618662A (zh) * | 2013-11-22 | 2014-03-05 | 奇智软件(北京)有限公司 | 一种实现即时通讯的方法和装置 |
US9614900B1 (en) * | 2014-06-19 | 2017-04-04 | Amazon Technologies, Inc. | Multi-process architecture for a split browser |
WO2017023332A1 (en) * | 2015-08-06 | 2017-02-09 | Hewlett Packard Enterprise Development Lp | Difference datasets |
CN107145529A (zh) * | 2017-04-17 | 2017-09-08 | 东软集团股份有限公司 | 一种数据处理方法及装置 |
CN107463370A (zh) * | 2017-06-30 | 2017-12-12 | 百度在线网络技术(北京)有限公司 | 跨进程渲染方法及系统 |
Non-Patent Citations (1)
Title |
---|
基于插件技术的GIS Server架构模型的设计;杨之江等;地球科学(中国地质大学学报);20100531;第35卷(第3期);第475-479页 * |
Also Published As
Publication number | Publication date |
---|---|
CN114510288A (zh) | 2022-05-17 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN108696381B (zh) | 一种协议配置方法及装置 | |
WO2019154353A1 (zh) | 系统运行参数查询方法、匹配方法、装置及节点设备 | |
US9215271B2 (en) | Method and apparatus for executing application of mobile device | |
CN109408086A (zh) | App的界面更新方法、装置、计算机设备及存储介质 | |
WO2020006929A1 (zh) | 数据校验方法、装置及计算机存储介质 | |
CN110471884A (zh) | 数据管理方法、装置、设备、系统及计算机可读存储介质 | |
CN111586097A (zh) | 一种网络请求处理方法、计算设备及存储介质 | |
CN111338608A (zh) | 分布式应用开发方法、装置、节点设备及可读存储介质 | |
CN112732468B (zh) | 数据处理方法、数据交互系统及计算设备 | |
CN110619204A (zh) | 一种邀请码生成方法、装置、终端设备及存储介质 | |
CN112925539B (zh) | 一种应用更新方法,计算设备及存储介质 | |
CN114168937A (zh) | 一种资源访问方法、计算设备及可读存储介质 | |
CN112380480B (zh) | 一种页面跳转方法、计算设备以及存储介质 | |
CN114510288B (zh) | 一种跨进程插件实现方法、计算设备及存储介质 | |
CN113535275A (zh) | 一种混合应用构建方法、装置及计算设备 | |
CN113961086B (zh) | 一种快捷键实现方法、计算设备及存储介质 | |
CN115904317A (zh) | 一种前后端接口统一调用方法、装置、设备及存储介质 | |
WO2022135410A1 (zh) | 加载源文件的方法及装置 | |
CN114461419A (zh) | 一种消息推送方法、系统、计算设备与可读存储介质 | |
CN113127123B (zh) | 一种窗口效果的生成方法及计算设备 | |
WO2020006930A1 (zh) | 数据伪造方法、装置及计算机存储介质 | |
CN113625922B (zh) | 一种文件翻译方法、计算设备及可读存储介质 | |
CN110716711A (zh) | 类的配置方法、装置、设备以及计算机存储介质 | |
CN117081838A (zh) | 多版本的平台登录方法、装置、计算机设备和存储介质 | |
CN115618147A (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 |