一种跨进程交互处理方法、移动终端以及计算机可读存储介质与流程

文档序号:11233942阅读:385来源:国知局
本发明涉及移动通信
技术领域
:,尤其涉及一种跨进程交互处理方法、移动终端以及计算机可读存储介质。
背景技术
::随着互联网的发展和终端的普及,终端的用户群越来越大,同时也对软件提出了更多智能,人性化的需求。在现有的技术中,其实终端,虽然被用户作为一个游戏机或电视机,还可能是一个学习机,还可能成为小宝宝的乐园等等,给我们的生活带来更多的乐趣。随着通讯产品的更新换代,移动终端(例如手机、个人数字化助理pda等)已成为人们必备的通讯工具。各种方便人们生活的功能都能在移动终端上实现,例如手机电视、gps、移动支付等等,都需要移动终端接入到互联网才能实现。随着电子产业的快速发展,移动终端智能化程度越来越高。移动终端研发公司也越来越注重智能化,人性化设计。在此移动终端快速发展的背景下,终端的便捷操作和人性化设计成为移动终端不可忽视的一部分。智能移动终端的性能和存储能力近几年有了长足的提升。无论从硬件还是软件本身都在迎合消费者不断追求最佳体验的需求。硬件的发展可以说是迅速的,新发布机型都会适配最新的硬件,使消费者从直观上对新发布机型的性能予以肯定。软件的设计可以说也是不断更新;能明显的感觉到,越高级的功能,应用之间交互能力越强的功能,越能迎合消费者的期待,甚至于超出消费者的预期。其效果就是新机型供不应求,消费者和终端厂商皆大欢喜。然而,现实情况是,跨应用交互能力越多的机型往往存在更多的问题;要么是同等配置下,应用的响应时间较长;要么就是应用体积很大,内存占用高居不下等等。目前对与跨进程交互的解决方案都比较笨拙。使用原生跨进程通信方式是普遍采用的,包括一对多的广播、点对点的binder等。其问题也都很明显,系统中充斥了大量的不相关广播,使系统和应用的性能越来越低;binder通信为大家所诟病的就是,数量有限,多线程竞争使用,且在通信过程中需要多次确认是否接收到数据,响应延迟极大。针对相关技术中跨进程之间的通信方式使系统和应用的性能越来越低,或响应延迟极大的问题,目前尚未提出解决方案。技术实现要素:本发明的主要目的在于提出一种跨进程交互处理方法、移动终端以及计算机可读存储介质,旨在解决相关技术中跨进程之间的通信方式使系统和应用的性能越来越低,或响应延迟极大的问题。为实现上述目的,本发明实施例提出一种跨进程交互处理方法,包括:接收一个或多个第一应用进程发送的注册请求消息,其中,所述注册请求消息中携带有请求进行交互的一个或多个第二应用进程的标识;根据所述注册请求消息与所述一个或多个第二应用进程之间创建管道连接;根据创建的管道连接实现所述一个或多个第一应用进程与所述一个或多个第二应用进行之间的交互。优选地,在根据所述注册请求消息与所述一个或多个第二应用进程之间创建管道连接之后,所述方法还包括:创建用于交互服务指令管理的虚拟文件,其中,所述虚拟文件用于所述一个或多个第一应用进程写入向所述一个或多个第二应用进程交互的内容。优选地,根据创建的管道连接实现所述一个或多个第一应用进程与所述一个或多个第二应用进行之间的交互包括:根据创建的管道连接接收所述一个或多个第一应用进程写入所述虚拟文件中的内容,其中,所述一个或多个第二应用进程根据创建的管道连接在所述一个或多个第一应用进程在写入的同时读取所述虚拟文件中的内容。优选地,所述方法还包括:缓存所述一个或多个第一应用与虚拟文件的映射列表;根据所述映射列表接收所述一个或多个第一应用进程写入到对应的虚拟文件中的内容。优选地,在根据创建的管道连接实现所述一个或多个第一应用进程与所述一个或多个第二应用进行之间的交互之后,所述方法还包括:接收所述一个或多个第一应用进程发送的反注册请求消息,其中,所述反注册请求消息用于请求断开与所述第二应用进程之间的交互;根据所述反注册请求消息断开与所述第二应用进程之间的管道连接。优选地,在根据所述反注册请求消息断开与所述第二应用进程之间的管道连接之后,所述方法还包括:删除所述一个或多个第一应用进程对应的虚拟文件和所述一个或多个第一应用与虚拟文件的映射列表。根据本发明实施例的另一方面,还提供了一种移动终端,所述移动终端包括处理器、存储器及通信总线;所述通信总线用于实现处理器和存储器之间的连接通信;所述处理器用于执行存储器中存储的跨进程交互处理程序,以实现以下步骤:接收一个或多个第一应用进程发送的注册请求消息,其中,所述注册请求消息中携带有请求进行交互的一个或多个第二应用进程的标识;根据所述注册请求消息与所述一个或多个第二应用进程之间创建管道连接;根据创建的管道连接实现所述一个或多个第一应用进程与所述一个或多个第二应用进行之间的交互。优选地,所述处理器还用于执行跨进程交互处理程序,以实现以下步骤:在根据所述注册请求消息与所述一个或多个第二应用进程之间创建管道管道连接之后,创建用于交互服务指令管理的虚拟文件,其中,所述虚拟文件用于所述一个或多个第一应用进程写入向所述一个或多个第二应用进程交互的内容。优选地,所述处理器还用于执行跨进程交互处理程序,以实现以下步骤:根据创建的管道连接接收所述一个或多个第一应用进程写入所述虚拟文件中的内容,其中,所述一个或多个第二应用进程根据创建的管道连接在所述一个或多个第一应用进程在写入的同时读取所述虚拟文件中的内容。优选地,所述处理器还用于执行跨进程交互处理程序,以实现以下步骤:缓存所述一个或多个第一应用与虚拟文件的映射列表;根据所述映射列表接收所述一个或多个第一应用进程写入到对应的虚拟文件中的内容。优选地,所述处理器还用于执行跨进程交互处理程序,以实现以下步骤:在根据创建的管道连接实现所述一个或多个第一应用进程与所述一个或多个第二应用进行之间的交互之后,接收所述一个或多个第一应用进程发送的反注册请求消息,其中,所述反注册请求消息用于请求断开与所述第二应用进程之间的交互;根据所述反注册请求消息断开与所述第二应用进程之间的管道连接。优选地,所述处理器还用于执行跨进程交互处理程序,以实现以下步骤:在根据所述反注册请求消息断开与所述第二应用进程之间的管道连接之后,删除所述一个或多个第一应用进程对应的虚拟文件和所述一个或多个第一应用与虚拟文件的映射列表。根据本发明实施例的另一方面,还提供了一种计算机可读存储介质,所述计算机可读存储介质存储有一个或者多个程序,所述一个或者多个程序可被一个或者多个处理器执行,以实现上述跨进程交互处理方法的步骤。通过本发明,接收一个或多个第一应用进程发送的注册请求消息,其中,所述注册请求消息中携带有请求进行交互的一个或多个第二应用进程的标识;根据所述注册请求消息与所述一个或多个第二应用进程之间创建管道连接;根据创建的管道连接实现所述一个或多个第一应用进程与所述一个或多个第二应用进行之间的交互,解决了相关技术中跨进程之间的通信方式使系统和应用的性能越来越低,或响应延迟极大的问题,通过创建的管道进行跨应用进程之间的交互,缩短了交互的时延,既可以减少广播的随意性,又可以提升点对点通信的效率,提高了用户体验。附图说明图1为实现本发明各个实施例一可选的移动终端的硬件结构示意图;图2为如图1所示的移动终端的无线通信系统示意图;图3是根据本发明实施例的跨进程交互处理方法的流程图;图4是根据本发明实施例的低延迟跨进程交互的示意图;图5是根据本发明实施例的低延迟跨进程交互的框架图;图6是根据本发明实施例的跨应用进程间交互的移动终端的框图。本发明目的的实现、功能特点及优点将结合实施例,参照附图做进一步说明。具体实施方式应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。在后续的描述中,使用用于表示元件的诸如“模块”、“部件”或“单元”的后缀仅为了有利于本发明的说明,其本身没有特定的意义。因此,“模块”、“部件”或“单元”可以混合地使用。终端可以以各种形式来实施。例如,本发明中描述的终端可以包括诸如手机、平板电脑、笔记本电脑、掌上电脑、个人数字助理(personaldigitalassistant,pda)、便捷式媒体播放器(portablemediaplayer,pmp)、导航装置、可穿戴设备、智能手环、计步器等移动终端,以及诸如数字tv、台式计算机等固定终端。后续描述中将以移动终端为例进行说明,本领域技术人员将理解的是,除了特别用于移动目的的元件之外,根据本发明的实施方式的构造也能够应用于固定类型的终端。请参阅图1,其为实现本发明各个实施例的一种移动终端的硬件结构示意图,该移动终端100可以包括:rf(radiofrequency,射频)单元101、wifi模块102、音频输出单元103、a/v(音频/视频)输入单元104、传感器105、显示单元106、用户输入单元107、接口单元108、存储器109、处理器110、以及电源111等部件。本领域技术人员可以理解,图1中示出的移动终端结构并不构成对移动终端的限定,移动终端可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件布置。下面结合图1对移动终端的各个部件进行具体的介绍:射频单元101可用于收发信息或通话过程中,信号的接收和发送,具体的,将基站的下行信息接收后,给处理器110处理;另外,将上行的数据发送给基站。通常,射频单元101包括但不限于天线、至少一个放大器、收发信机、耦合器、低噪声放大器、双工器等。此外,射频单元101还可以通过无线通信与网络和其他设备通信。上述无线通信可以使用任一通信标准或协议,包括但不限于gsm(globalsystemofmobilecommunication,全球移动通讯系统)、gprs(generalpacketradioservice,通用分组无线服务)、cdma2000(codedivisionmultipleaccess2000,码分多址2000)、wcdma(widebandcodedivisionmultipleaccess,宽带码分多址)、td-scdma(timedivision-synchronouscodedivisionmultipleaccess,时分同步码分多址)、fdd-lte(frequencydivisionduplexing-longtermevolution,频分双工长期演进)和tdd-lte(timedivisionduplexing-longtermevolution,分时双工长期演进)等。wifi属于短距离无线传输技术,移动终端通过wifi模块102可以帮助用户收发电子邮件、浏览网页和访问流式媒体等,它为用户提供了无线的宽带互联网访问。虽然图1示出了wifi模块102,但是可以理解的是,其并不属于移动终端的必须构成,完全可以根据需要在不改变发明的本质的范围内而省略。音频输出单元103可以在移动终端100处于呼叫信号接收模式、通话模式、记录模式、语音识别模式、广播接收模式等等模式下时,将射频单元101或wifi模块102接收的或者在存储器109中存储的音频数据转换成音频信号并且输出为声音。而且,音频输出单元103还可以提供与移动终端100执行的特定功能相关的音频输出(例如,呼叫信号接收声音、消息接收声音等等)。音频输出单元103可以包括扬声器、蜂鸣器等等。a/v输入单元104用于接收音频或视频信号。a/v输入单元104可以包括图形处理器(graphicsprocessingunit,gpu)1041和麦克风1042,图形处理器1041对在视频捕获模式或图像捕获模式中由图像捕获装置(如摄像头)获得的静态图片或视频的图像数据进行处理。处理后的图像帧可以显示在显示单元106上。经图形处理器1041处理后的图像帧可以存储在存储器109(或其它存储介质)中或者经由射频单元101或wifi模块102进行发送。麦克风1042可以在电话通话模式、记录模式、语音识别模式等等运行模式中经由麦克风1042接收声音(音频数据),并且能够将这样的声音处理为音频数据。处理后的音频(语音)数据可以在电话通话模式的情况下转换为可经由射频单元101发送到移动通信基站的格式输出。麦克风1042可以实施各种类型的噪声消除(或抑制)算法以消除(或抑制)在接收和发送音频信号的过程中产生的噪声或者干扰。移动终端100还包括至少一种传感器105,比如光传感器、运动传感器以及其他传感器。具体地,光传感器包括环境光传感器及接近传感器,其中,环境光传感器可根据环境光线的明暗来调节显示面板1061的亮度,接近传感器可在移动终端100移动到耳边时,关闭显示面板1061和/或背光。作为运动传感器的一种,加速计传感器可检测各个方向上(一般为三轴)加速度的大小,静止时可检测出重力的大小及方向,可用于识别手机姿态的应用(比如横竖屏切换、相关游戏、磁力计姿态校准)、振动识别相关功能(比如计步器、敲击)等;至于手机还可配置的指纹传感器、压力传感器、虹膜传感器、分子传感器、陀螺仪、气压计、湿度计、温度计、红外线传感器等其他传感器,在此不再赘述。显示单元106用于显示由用户输入的信息或提供给用户的信息。显示单元106可包括显示面板1061,可以采用液晶显示器(liquidcrystaldisplay,lcd)、有机发光二极管(organiclight-emittingdiode,oled)等形式来配置显示面板1061。用户输入单元107可用于接收输入的数字或字符信息,以及产生与移动终端的用户设置以及功能控制有关的键信号输入。具体地,用户输入单元107可包括触控面板1071以及其他输入设备1072。触控面板1071,也称为触摸屏,可收集用户在其上或附近的触摸操作(比如用户使用手指、触笔等任何适合的物体或附件在触控面板1071上或在触控面板1071附近的操作),并根据预先设定的程式驱动相应的连接装置。触控面板1071可包括触摸检测装置和触摸控制器两个部分。其中,触摸检测装置检测用户的触摸方位,并检测触摸操作带来的信号,将信号传送给触摸控制器;触摸控制器从触摸检测装置上接收触摸信息,并将它转换成触点坐标,再送给处理器110,并能接收处理器110发来的命令并加以执行。此外,可以采用电阻式、电容式、红外线以及表面声波等多种类型实现触控面板1071。除了触控面板1071,用户输入单元107还可以包括其他输入设备1072。具体地,其他输入设备1072可以包括但不限于物理键盘、功能键(比如音量控制按键、开关按键等)、轨迹球、鼠标、操作杆等中的一种或多种,具体此处不做限定。进一步的,触控面板1071可覆盖显示面板1061,当触控面板1071检测到在其上或附近的触摸操作后,传送给处理器110以确定触摸事件的类型,随后处理器110根据触摸事件的类型在显示面板1061上提供相应的视觉输出。虽然在图1中,触控面板1071与显示面板1061是作为两个独立的部件来实现移动终端的输入和输出功能,但是在某些实施例中,可以将触控面板1071与显示面板1061集成而实现移动终端的输入和输出功能,具体此处不做限定。接口单元108用作至少一个外部装置与移动终端100连接可以通过的接口。例如,外部装置可以包括有线或无线头戴式耳机端口、外部电源(或电池充电器)端口、有线或无线数据端口、存储卡端口、用于连接具有识别模块的装置的端口、音频输入/输出(i/o)端口、视频i/o端口、耳机端口等等。接口单元108可以用于接收来自外部装置的输入(例如,数据信息、电力等等)并且将接收到的输入传输到移动终端100内的一个或多个元件或者可以用于在移动终端100和外部装置之间传输数据。存储器109可用于存储软件程序以及各种数据。存储器109可主要包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需的应用程序(比如声音播放功能、图像播放功能等)等;存储数据区可存储根据手机的使用所创建的数据(比如音频数据、电话本等)等。此外,存储器109可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件、闪存器件、或其他易失性固态存储器件。处理器110是移动终端的控制中心,利用各种接口和线路连接整个移动终端的各个部分,通过运行或执行存储在存储器109内的软件程序和/或模块,以及调用存储在存储器109内的数据,执行移动终端的各种功能和处理数据,从而对移动终端进行整体监测。处理器110可包括一个或多个处理单元;优选的,处理器110可集成应用处理器和调制解调处理器,其中,应用处理器主要处理操作系统、用户界面和应用程序等,调制解调处理器主要处理无线通信。可以理解的是,上述调制解调处理器也可以不集成到处理器110中。移动终端100还可以包括给各个部件供电的电源111(比如电池),优选的,电源111可以通过电源管理系统与处理器110逻辑相连,从而通过电源管理系统实现管理充电、放电、以及功耗管理等功能。尽管图1未示出,移动终端100还可以包括蓝牙模块等,在此不再赘述。为了便于理解本发明实施例,下面对本发明的移动终端所基于的通信网络系统进行描述。请参阅图2,图2为本发明实施例提供的一种通信网络系统架构图,该通信网络系统为通用移动通信技术的lte系统,该lte系统包括依次通讯连接的ue(userequipment,用户设备)201,e-utran(evolvedumtsterrestrialradioaccessnetwork,演进式umts陆地无线接入网)202,epc(evolvedpacketcore,演进式分组核心网)203和运营商的ip业务204。具体地,ue201可以是上述终端100,此处不再赘述。e-utran202包括enodeb2021和其它enodeb2022等。其中,enodeb2021可以通过回程(backhaul)(例如x2接口)与其它enodeb2022连接,enodeb2021连接到epc203,enodeb2021可以提供ue201到epc203的接入。epc203可以包括mme(mobilitymanagemententity,移动性管理实体)2031,hss(homesubscriberserver,归属用户服务器)2032,其它mme2033,sgw(servinggateway,服务网关)2034,pgw(pdngateway,分组数据网络网关)2035和pcrf(policyandchargingrulesfunction,政策和资费功能实体)2036等。其中,mme2031是处理ue201和epc203之间信令的控制节点,提供承载和连接管理。hss2032用于提供一些寄存器来管理诸如归属位置寄存器(图中未示)之类的功能,并且保存有一些有关服务特征、数据速率等用户专用的信息。所有用户数据都可以通过sgw2034进行发送,pgw2035可以提供ue201的ip地址分配以及其它功能,pcrf2036是业务数据流和ip承载资源的策略与计费控制策略决策点,它为策略与计费执行功能单元(图中未示)选择及提供可用的策略和计费控制决策。ip业务204可以包括因特网、内联网、ims(ipmultimediasubsystem,ip多媒体子系统)或其它ip业务等。虽然上述以lte系统为例进行了介绍,但本领域技术人员应当知晓,本发明不仅仅适用于lte系统,也可以适用于其他无线通信系统,例如gsm、cdma2000、wcdma、td-scdma以及未来新的网络系统等,此处不做限定。基于上述移动终端硬件结构以及通信网络系统,提出本发明方法各个实施例。实施例1基于上述的移动终端,本发明实施例提供了一种跨进程交互处理方法,图3是根据本发明实施例的跨进程交互处理方法的流程图一,如图3所示,该方法包括以下步骤:步骤s301,接收一个或多个第一应用进程发送的注册请求消息,其中,所述注册请求消息中携带有请求进行交互的一个或多个第二应用进程的标识;步骤s302,根据所述注册请求消息与所述一个或多个第二应用进程之间创建管道连接;步骤s303,根据创建的管道连接实现所述一个或多个第一应用进程与所述一个或多个第二应用进行之间的交互。通过实施步骤,接收一个或多个第一应用进程发送的注册请求消息,其中,所述注册请求消息中携带有请求进行交互的一个或多个第二应用进程的标识;根据所述注册请求消息与所述一个或多个第二应用进程之间创建管道连接;根据创建的管道连接实现所述一个或多个第一应用进程与所述一个或多个第二应用进行之间的交互,解决了相关技术中跨进程之间的通信方式使系统和应用的性能越来越低,或响应延迟极大的问题,通过创建的管道进行跨应用进程之间的交互,缩短了交互的时延,既可以减少广播的随意性,又可以提升点对点通信的效率,提高了用户体验。优选地,在根据所述注册请求消息与所述一个或多个第二应用进程之间创建管道连接之后,所述方法还包括:创建用于交互服务指令管理的虚拟文件,其中,所述虚拟文件用于所述一个或多个第一应用进程写入向所述一个或多个第二应用进程交互的内容。优选地,根据创建的管道连接实现所述一个或多个第一应用进程与所述一个或多个第二应用进行之间的交互包括:根据创建的管道连接接收所述一个或多个第一应用进程写入所述虚拟文件中的内容,其中,所述一个或多个第二应用进程根据创建的管道连接在所述一个或多个第一应用进程在写入的同时读取所述虚拟文件中的内容。优选地,所述方法还包括:缓存所述一个或多个第一应用与虚拟文件的映射列表;根据所述映射列表接收所述一个或多个第一应用进程写入到对应的虚拟文件中的内容。优选地,在根据创建的管道连接实现所述一个或多个第一应用进程与所述一个或多个第二应用进行之间的交互之后,所述方法还包括:接收所述一个或多个第一应用进程发送的反注册请求消息,其中,所述反注册请求消息用于请求断开与所述第二应用进程之间的交互;根据所述反注册请求消息断开与所述第二应用进程之间的管道连接。优选地,在根据所述反注册请求消息断开与所述第二应用进程之间的管道连接之后,所述方法还包括:删除所述一个或多个第一应用进程对应的虚拟文件和所述一个或多个第一应用与虚拟文件的映射列表。上述的管道连接优选为管道pipe连接,下面以使用不同的进程区分数据操作与图形绘制,使得数据操作进程与图形绘制进程之间实现跨进程交互连接为例对本发明实施例进行进一步说明。在本发明实施例中,所述跨进程可为数据操作进程与图形绘制进程之间的跨进程交互,可以理解,该跨进程也可以为其他两个进程之间的跨进程交互操作,并不限定于所述数据操作进程与图形绘制进程之间的跨进程交互,本实施例仅以此为例加以说明。所述数据操作进程与图形绘制进程交互通信在移动终端中完成,本实施例中,移动终端可以是装载有控制软件的,并且具有计算能力的电脑、智能手机、电视机以及各种家庭智能设备、商用智能设备、办公智能设备、移动互联网设备(mobileinternetdevices,简称为mid)等,本发明实施例不作具体限定。图4是根据本发明实施例的低延迟跨进程交互的示意图,如图4所示,所述跨进程交互至少包括:第二应用进程与第一应用进程实现跨进程交互连接,在本发明实施例中,所述第一应用进程可为数据操作进程,所述第二应用进程可为图形绘制进程,该第一应用进程与第二应用进程可通过管道pipe实现跨进程交互连接。所述pipe作为跨进程通信方式,其不但可用于单机内的进程间通信,还可用于不同移动终端的应用进程之间的通信。第一应用进程和第二应用进程均向第三进程发送跨进程交互连接请求,其中,所述跨进程交互连接请求中携带有要连接的目标应用进程,即携带有第一应用进程中携带有第二应用进程的标识信息,所述第三进程根据所述跨进程交互连接请求,创建第一应用进程与第二应用进程之间的跨进程交互连接。在本发明实施例中,当所述数据操作进程接收到所述图形绘制进程的跨进程交互连接请求时,该数据操作进程反馈跨进程交互连接响应,建立从该数据操作进程到所述图形绘制进程的通信通道,并可根据所述请求的类型加载相应的服务模块。该数据操作进程与图形绘制进程之间通过pipe进行跨进程交互连接,第三进行接收到第一应用进程和第二应用进程之后使得第一应用进程和第二应用进程建立管道连接,其中,第三进程可以是框架进程,并根据连接启动的方式以及要连接的目标,所述第一应用进程与第二应用进程之间通过pipe跨进程交互连接的过程包括:在接收到第一应用进程发送的跨进程交互连接请求之后,该第三进程监听是否有其他进程的连接请求;具体为,该第三进程创建虚拟文件,并绑定具有文件描述符的文件,并监听是否有其他对应于该文件描述符的本地pipe连接请求;所述第二应用进程发出pipe连接请求之后,第三进程创建虚拟文件,并绑定与所述第一应用进程的文件描述符相对应的文件,该第二应用进程在发起跨进程连接请求时便描述其要连接的第一应用进程,指出该第二应用进程pipe的文件路径,然后向第一应用进程发出pipe连接请求;所述第三进程监听到或接收到第二应用进程的连接请求,并响应该连接请求以建立一个新的路径,创建与第一应用进程和第二应用进程对应的虚拟文件,则所述第一应用进程与第二应用进程之间建立pipe跨进程交互连接以接收/发送数据。相关技术中,需要第二应用进程向第一应用进程发送获取所述数据操作对象的请求,所述数据操作进程通知所述图形绘制进程有新的数据操作对象,该图形绘制进程接收到所述有新数据操作对象的通知时,所述图形绘制进程向数据操作进程发送获取所述数据操作对象的请求。第一应用进程根据上述请求生成相应的数据操作对象集合并将该数据操作对象集合发送至第二应用进程。需要多次的确认过程,导致时延比较长。在本发明实施例中,第三进程创建与第一应用进程和第应用进程对应的虚拟文件,且缓存第一应用进程与对应的虚拟文件的映射列表,第二应用进程与对应的虚拟文件的映射列表,在第一应用进程或第二应用进程往所述第一应用进程对应的虚拟文件中写数据时,第二应用进程或第一应用进程直接从所述虚拟文件中读数据,实现第一应用进程与第二应用进程之间的数据交互,从而节省数据传输时间,而且不会耗费大量的网络资源。本发明实施例所述的跨进程交互方法中,使用不同的进程区分数据操作与图形绘制,使得数据操作进程与图形绘制进程之间实现跨进程交互连接,简化了跨进程通信过程中通道建立过程,提高了数据处理效率。而且,基于该数据操作进程与图形绘制进程之间实现跨进程交互通信,即使计算机系统在面对大量的网络数据改变操作时,也可以流畅有效地绘制图形和处理用户的操作,而且能保证动画的平顺播放。在本发明实施例中,所述跨进程可为数据操作进程与图形绘制进程之间的跨进程交互,可以理解,该跨进程也可以为其他两个进程之间的跨进程交互操作,并不限定于所述数据操作进程与图形绘制进程之间的跨进程交互,本实施例仅以此为例加以说明。所述数据操作进程与图形绘制进程交互通信在移动终端中完成,本实施例中,移动终端可以是装载有控制软件的,并且具有计算能力的电脑、智能手机、电视机以及各种家庭智能设备、商用智能设备、办公智能设备、移动互联网设备(mobileinternetdevices,mid)等,本发明实施例不作具体限定。通过本发明实施例,简化了跨进程通信过程中通道建立过程,提高了数据处理效率。而且,基于该数据操作进程与图形绘制进程之间实现跨进程交互通信,即使计算机系统在面对大量的网络数据改变操作时,也可流畅有效地绘制图形和处理用户的操作,而且能保证动画的平顺播放。实施例2跨进程交互,也可以叫做跨应用交互,也是未来移动终端应用设计的趋势。以往的应用设计和实现都是封闭的,即应用自身的功能仅仅依赖自身的其它模块提供的实现即可;对其它进程是透明的,也就是说,进程与进程之间相互没有通信的需求;或者特定场景下的非实时通信。然而,随着移动终端的普及度的提升,需求随之增加,应用之间的交互变的越来越趋于频繁。android原生也提供了跨进程交互的方式;其交互的成本很高,对于非实时的交互需求尚可勉强对付;但是,实时交互的要求,近似于同一应用内部的响应速度,原生的ipc通信可以说是无能为力。所以,目前对于跨进程交互度较高的功能,rom厂商只得采取应用合并的方式实现;这样的结果是,单个应用的体积变的越来越大;规模也越来越复杂;这从软件开发的角度看,是开发模式的一种退步。针对上述问题,本发明实施例采用linux底层提供的pipe和虚拟文件的方式实现原声binder的跨进程交互功能。应用之间可以使用应用包名等进行相互注册和反注册,实现点对点的通信;通信的管理由通用管理模块统一调度,应用之间无需关心交互的具体实现方式;可以专注于应用业务的实现。这种交互从交互的响应速度上明显优于android原声的binder通信方式,也高于传统的socket的低速点对点通信方式。本发明实施例还提供了一跨进程交互的装置,应用于移动终端,图5是根据本发明实施例的低延迟跨进程交互的框架图,如图5所示,该装置主要包括交互代理模块、交互服务模块53、交互注册/反注册模块54、虚拟文件管理模块55、虚拟文件创建/销毁模块57、管道管理模块56和管道创建/销毁模块58,下面对各个模块以及各个模块之间的交互进行简要说明。交互代理模块51位于第一应用进程,交互代理模块52位于第二应用进程,分别为第一应用进程和第二应用进程与应用之间交互的代理,与框架层的交互服务模块53和管道进行交互;主要用于接收客户端的注册和反注册调度,进而调用交互服务模块53,以及接收客户端进程的交互指令,利用底层为其建立的管道进行交互;交互服务模块53,为常驻服务,用于接受各应用进程的交互代理模块的注册和反注册请求,同时将下层建立的对应管道应用返回给交互代理模块;交互注册/反注册模块54,用于统一按照交互服务的指令管理虚拟文件和管道的管理调度工作;当接收到注册指令后,调度虚拟文件管理模块55,发出创建请求;同时,调度管道管理模块56,发出创建请求;当接收到反注册指令后,调度虚拟文件管理模块55和管道管理模块56,发出销毁请求;虚拟文件管理模块55,用于映射缓存、统一管理各进程已建立的虚拟文件;同时在接收到创建/销毁请求后,调度虚拟文件创建和销毁模块创建和销毁具体的虚拟文件;同时,从添加/移除缓存的映射;虚拟文件创建/销毁模块57,用于响应虚拟文件管理模块55的请求,调用系统接口创建或销毁虚拟文件;管道管理模块56,用于映射缓存、统一管理各进程已建立的通信管道;同时在接收到创建/销毁请求后,调度管道创建和销毁模块创建和销毁具体的管道;同时,添加/移除缓存的映射;管道创建/销毁模块58,用于响应管道管理模块56的请求,调用系统接口创建或销毁管道。通过上述装置就可以有效的提升跨进程点对点的通信效率,提升用户的体验。本发明实施例采用linux底层提供的pipe管道和虚拟文件的方式实现原声binder的跨进程交互功能。应用之间可以使用应用包名等进行相互注册和反注册,实现点对点的通信;通信的管理由通用管理模块统一调度,应用之间无需关心交互的具体实现方式;可以专注于应用业务的实现。这样,从开发人员角度上讲,可以使其专注于业务开发,由框架层提供高效的跨进程通信实现;从消费者讲,享受交互更加丰富的应用设计的同时,还可以使用户的流畅性体验得到极大的提升。实施例3根据本发明实施例的另一方面,还提供了一种移动终端,图6是根据本发明实施例的跨应用进程间交互的移动终端的框图,如图6所示,所述移动终端包括处理器、存储器及通信总线;所述通信总线用于实现处理器和存储器之间的连接通信;所述处理器用于执行存储器中存储的跨进程交互处理程序,以实现以下步骤:接收一个或多个第一应用进程发送的注册请求消息,其中,所述注册请求消息中携带有请求进行交互的一个或多个第二应用进程的标识;根据所述注册请求消息与所述一个或多个第二应用进程之间创建管道连接;根据创建的管道连接实现所述一个或多个第一应用进程与所述一个或多个第二应用进行之间的交互。优选地,所述处理器还用于执行跨进程交互处理程序,以实现以下步骤:在根据所述注册请求消息与所述一个或多个第二应用进程之间创建管道管道连接之后,创建用于交互服务指令管理的虚拟文件,其中,所述虚拟文件用于所述一个或多个第一应用进程写入向所述一个或多个第二应用进程交互的内容。优选地,所述处理器还用于执行跨进程交互处理程序,以实现以下步骤:根据创建的管道连接接收所述一个或多个第一应用进程写入所述虚拟文件中的内容,其中,所述一个或多个第二应用进程根据创建的管道连接在所述一个或多个第一应用进程在写入的同时读取所述虚拟文件中的内容。优选地,所述处理器还用于执行跨进程交互处理程序,以实现以下步骤:缓存所述一个或多个第一应用与虚拟文件的映射列表;根据所述映射列表接收所述一个或多个第一应用进程写入到对应的虚拟文件中的内容。优选地,所述处理器还用于执行跨进程交互处理程序,以实现以下步骤:在根据创建的管道连接实现所述一个或多个第一应用进程与所述一个或多个第二应用进行之间的交互之后,接收所述一个或多个第一应用进程发送的反注册请求消息,其中,所述反注册请求消息用于请求断开与所述第二应用进程之间的交互;根据所述反注册请求消息断开与所述第二应用进程之间的管道连接。优选地,所述处理器还用于执行跨进程交互处理程序,以实现以下步骤:在根据所述反注册请求消息断开与所述第二应用进程之间的管道连接之后,删除所述一个或多个第一应用进程对应的虚拟文件和所述一个或多个第一应用与虚拟文件的映射列表。根据本发明实施例的另一方面,还提供了一种计算机可读存储介质,所述计算机可读存储介质存储有一个或者多个程序,所述一个或者多个程序可被一个或者多个处理器执行,以实现上述跨进程交互处理方法的步骤。本发明实施例,接收一个或多个第一应用进程发送的注册请求消息,其中,所述注册请求消息中携带有请求进行交互的一个或多个第二应用进程的标识;根据所述注册请求消息与所述一个或多个第二应用进程之间创建管道连接;根据创建的管道连接实现所述一个或多个第一应用进程与所述一个或多个第二应用进行之间的交互,解决了相关技术中跨进程之间的通信方式使系统和应用的性能越来越低,或响应延迟极大的问题,通过创建的管道进行跨应用进程之间的交互,缩短了交互的时延,既可以减少广播的随意性,又可以提升点对点通信的效率,提高了用户体验。需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者装置不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者装置所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、方法、物品或者装置中还存在另外的相同要素。上述本发明实施例序号仅仅为了描述,不代表实施例的优劣。通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如rom/ram、磁碟、光盘)中,包括若干指令用以使得一台终端(可以是手机,计算机,服务器,空调器,或者网络设备等)执行本发明各个实施例所述的方法。上面结合附图对本发明的实施例进行了描述,但是本发明并不局限于上述的具体实施方式,上述的具体实施方式仅仅是示意性的,而不是限制性的,本领域的普通技术人员在本发明的启示下,在不脱离本发明宗旨和权利要求所保护的范围情况下,还可做出很多形式,这些均属于本发明的保护之内。当前第1页12当前第1页12
当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1