CN106547634A - 一种跨进程通信的方法及装置 - Google Patents

一种跨进程通信的方法及装置 Download PDF

Info

Publication number
CN106547634A
CN106547634A CN201611058913.4A CN201611058913A CN106547634A CN 106547634 A CN106547634 A CN 106547634A CN 201611058913 A CN201611058913 A CN 201611058913A CN 106547634 A CN106547634 A CN 106547634A
Authority
CN
China
Prior art keywords
application program
identification number
communicated
communication
application
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
CN201611058913.4A
Other languages
English (en)
Other versions
CN106547634B (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.)
Baosheng China Technology Industry Co ltd
Original Assignee
Wuhan Douyu Network 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 Douyu Network Technology Co Ltd filed Critical Wuhan Douyu Network Technology Co Ltd
Priority to CN201611058913.4A priority Critical patent/CN106547634B/zh
Publication of CN106547634A publication Critical patent/CN106547634A/zh
Priority to PCT/CN2017/079614 priority patent/WO2018094951A1/zh
Application granted granted Critical
Publication of CN106547634B publication Critical patent/CN106547634B/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/46Multiprogramming arrangements
    • G06F9/54Interprogram communication
    • G06F9/541Interprogram communication via adapters, e.g. between incompatible applications
    • 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/46Multiprogramming arrangements
    • G06F9/54Interprogram communication
    • G06F9/544Buffers; Shared memory; Pipes

Landscapes

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

Abstract

本发明提供了一种跨进程通信的方法及装置,其中,该方法包括:获取待通信进程的第一标识号,待通信进程属于第一应用程序;基于第一标识号建立目标进程与待通信进程之间的通信通道,目标进程属于第二应用程序,第二应用程序和第一应用程序为终端的两个不同的应用程序;通过通信通道将待通信进程的访问请求发送至目标进程,以进行第一应用程序与第二应用程序的通信,其无需参数配置,操作简单,适用性较强,且基于第一标识号建立的通信通道实现高流量的数据承载,实用性较佳。

Description

一种跨进程通信的方法及装置
技术领域
本发明涉及手机应用技术领域,具体而言,涉及一种跨进程通信的方法及装置。
背景技术
Android系统是一种手持设备(如手机、平板电脑等)的操作系统。由于Android系统比较封闭,每个应用程序只能在为该改程序创建的文件系统中读取文件,不可以去其它地方访问。
Android系统的上述特点在保证整个系统的安全性和稳定性的同时,也在其他方面存在着明显的缺陷。例如,由于android系统中应用程序之间不能共享内存,使得每个程序相互独立,导致不同的应用程序之间基本无法直接实现相互通信。
现有技术中提供了一种基于AIDL(接口定义语言)的跨应用程序进程的通信方法,该方法需要首先在服务端进行AIDL接口的定义和相应的参数配置,然后在客户端完成服务端通过上述定义和配置所能够实现的跨进程通信方法。
发明人在研究中发现,现有技术中的跨应用程序进程的通信方法,参数配置的复杂度较高,导致适用性较差,且受限于AIDL传递参数的大小而导致通信的数据承载量较低。
发明内容
有鉴于此,本发明的目的在于提供一种跨进程通信的方法及装置,操作简单,适用性较强,且能够承载高流量的数据通信,实用性较佳。
第一方面,本发明实施例提供了一种跨进程通信的方法,所述方法包括:
获取待通信进程的第一标识号,所述待通信进程属于第一应用程序;
基于所述第一标识号建立目标进程与所述待通信进程之间的通信通道,所述目标进程属于第二应用程序,所述第二应用程序和所述第一应用程序为终端的两个不同的应用程序;
通过所述通信通道将所述待通信进程的访问请求发送至所述目标进程,以进行所述第一应用程序与所述第二应用程序的通信。
结合第一方面,本发明实施例提供了第一方面的第一种可能的实施方式,其中,所述获取待通信进程的第一标识号和所述基于所述第一标识号建立目标进程与所述待通信进程之间的通信通道之间,包括:
获取所述终端的进程队列,所述进程队列为所述终端当前启用的所有应用进程的集合;
对所述进程队列中的每个所述应用进程均提取对应的第二标识号;
基于所述第二标识号获取所述应用进程对应的应用程序的包名;
建立所述第二标识号和所述包名之间的映射关系。
结合第一方面的第一种可能的实施方式,本发明实施例提供了第一方面的第二种可能的实施方式,其中,所述建立所述第二标识号和所述包名之间的映射关系之后,包括:
基于所述映射关系,判断所述第二应用程序是否获取到对应的目标进程的第三标识号;
所述基于所述第一标识号建立目标进程与所述待通信进程之间的通信通道,包括:
在判断出所述第二应用程序获取到对应的所述第三标识号后,基于所述第一标识号建立目标进程与所述待通信进程之间的通信通道。
结合第一方面或第一方面的第二种可能的实施方式,本发明实施例提供了第一方面的第三种可能的实施方式,其中,所述基于所述第一标识号建立目标进程与所述待通信进程之间的通信通道,包括:
基于所述第一标识号对所述目标进程配置socket连接;基于所述socket连接建立所述目标进程与所述待通信进程之间的通信通道。
结合第一方面,本发明实施例提供了第一方面的第四种可能的实施方式,其中,还包括:
基于所述第一标识号对所述第一应用程序与所述第二应用程序的通信进行实时监听,以判断所述目标进程是否已经接收所述待通信进程的所述访问请求。
第二方面,本发明实施例还提供了一种跨进程通信的装置,所述装置包括:
第一获取模块,用于获取待通信进程的第一标识号,所述待通信进程属于第一应用程序;
第一建立模块,用于基于所述第一标识号建立目标进程与所述待通信进程之间的通信通道,所述目标进程属于第二应用程序,所述第二应用程序和所述第一应用程序为终端的两个不同的应用程序;
通信模块,用于通过所述通信通道将所述待通信进程的访问请求发送至所述目标进程,以进行所述第一应用程序与所述第二应用程序的通信。
结合第二方面,本发明实施例提供了第二方面的第一种可能的实施方式,其中,还包括:
第二获取模块,用于获取所述终端的进程队列,所述进程队列为所述终端当前启用的所有应用进程的集合;
提取模块,用于对所述进程队列中的每个所述应用进程均提取对应的第二标识号;
第三获取模块,用于基于所述第二标识号获取所述应用进程对应的应用程序的包名;
第二建立模块,用于建立所述第二标识号和所述包名之间的映射关系。
结合第二方面的第一种可能的实施方式,本发明实施例提供了第二方面的第二种可能的实施方式,其中,还包括判断模块;
所述判断模块,用于基于所述映射关系,判断所述第二应用程序是否获取到对应的目标进程的第三标识号;
所述第一建立模块,还用于在判断出所述第二应用程序获取到对应的所述第三标识号后,基于所述第一标识号建立目标进程与所述待通信进程之间的通信通道。
结合第二方面或第二方面的第二种可能的实施方式,本发明实施例提供了第二方面的第三种可能的实施方式,其中,所述第一建立模块包括:
配置单元,用于基于所述第一标识号对所述目标进程配置socket连接;
建立单元,用于基于所述socket连接建立所述目标进程与所述待通信进程之间的通信通道。
结合第二方面,本发明实施例提供了第二方面的第四种可能的实施方式,其中,还包括监听模块;
所述监听模块,用于基于所述第一标识号对所述第一应用程序与所述第二应用程序的通信进行实时监听,以判断所述目标进程是否已经接收所述待通信进程的所述访问请求。
本发明实施例提供的跨进程通信的方法及装置,与现有技术中的跨应用程序进程的通信方法,参数配置的复杂度较高,导致适用性较差,且可通信的数据承载量较低相比,其首先获取第一应用程序对应的待通信进程的第一标识号,然后基于该第一标识号建立目标进程与待通信进程之间的通信通道,其中,目标进程属于第二应用程序,第二应用程序和上述第一应用程序为终端的两个不同的应用程序,最后通过通信通道将待通信进程的访问请求发送至目标进程,以进行第一应用程序与第二应用程序的通信,其无需参数配置,操作简单,适用性较强,且基于第一标识号建立的通信通道实现高流量的数据承载,实用性较佳。
为使本发明的上述目的、特征和优点能更明显易懂,下文特举较佳实施例,并配合所附附图,作详细说明如下。
附图说明
为了更清楚地说明本发明实施例的技术方案,下面将对实施例中所需要使用的附图作简单地介绍,应当理解,以下附图仅示出了本发明的某些实施例,因此不应被看作是对范围的限定,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他相关的附图。
图1示出了本发明实施例所提供的一种跨进程通信的方法的流程图;
图2示出了本发明实施例所提供的另一种跨进程通信的方法的流程图;
图3示出了本发明实施例所提供的另一种跨进程通信的方法的流程图;
图4示出了本发明实施例所提供的一种跨进程通信的装置的结构示意图;
图5示出了本发明实施例所提供的一种跨进程通信的装置中第一建立模块的结构示意图。
主要元件符号说明:
11、第一获取模块;22、第一建立模块;33、通信模块;221、配置单元;222、建立单元。
具体实施方式
为使本发明实施例的目的、技术方案和优点更加清楚,下面将结合本发明实施例中附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。通常在此处附图中描述和示出的本发明实施例的组件可以以各种不同的配置来布置和设计。因此,以下对在附图中提供的本发明的实施例的详细描述并非旨在限制要求保护的本发明的范围,而是仅仅表示本发明的选定实施例。基于本发明的实施例,本领域技术人员在没有做出创造性劳动的前提下所获得的所有其他实施例,都属于本发明保护的范围。
考虑到现有技术中的跨应用程序进程的通信方法,参数配置的复杂度较高,导致适用性较差,且受限于AIDL传递参数的大小而导致通信的数据承载量较低。基于此,本发明实施例提供了一种跨进程通信的方法及装置,其操作简单,适用性较强,且能够承载高流量的数据通信,实用性较佳。
另外,在阐述本发明实施例提供的跨进程通信的方法及装置之前,首先对本发明实施例的应用场景做简要说明。
本发明实施例是实现同一个终端设备中的两个不同应用程序之间的通信,其中,上述终端的应用系统可以为Android系统,可以为IOS系统,还可以是其他应用系统。那么,上述应用程序可以是基于Android平台运行的应用程序,还可以是基于IOS平台运行的应用程序,以满足不同用户的不同需求,考虑到Android系统应用的广泛性和兼容性,本发明实施例优选的采用Android终端。
参见图1所示的本发明实施例所提供的跨进程通信的方法的流程图,所述方法具体包括如下步骤:
S101、获取待通信进程的第一标识号,待通信进程属于第一应用程序;
具体的,本发明实施例所提供的跨进程通信的方法首先获取待通信进程的第一标识号,在Android应用中,本发明实施例使用int pid=android.os.Process.myPid()的方式来获取到第一应用程序的第一标识号(进程代号pid)。该pid为Android系统中每个进程的一个单独一串数字,使用该数字来确定进程在系统中的唯一性,因此,该进程的pid可以作为进程间通讯的一个锚点来使用。就是说,其他进程可以通过该pid来连接并发送数据给本进程。
S102、基于第一标识号建立目标进程与待通信进程之间的通信通道,目标进程属于第二应用程序,第二应用程序和第一应用程序为终端的两个不同的应用程序;
具体的,本发明实施例所提供的跨进程通信的方法能够建立目标进程与待通信进程之间的通信通道,其该通信通道的建立依赖于上述第一标识号。
其中,上述目标进程属于第二应用进程,且该第二应用进程与上述第一应用进程属于终端的两个不同的应用程序,通过上述通信通道的建立即可实现这两个不同应用程序之间的通信。
S103、通过通信通道将待通信进程的访问请求发送至目标进程,以进行第一应用程序与第二应用程序的通信。
具体的,本发明实施例所提供的跨进程通信的方法,对于待通信进程发送的访问请求,将通过上述通信通道发送至目标进程,以进行第一应用程序与第二应用程序之间的通信。
值得提出的是,本发明实施例中的待通信进程通过上述通信通道可以单向访问目标进程,还可以对目标进程建立新的通信通道,以实现目标进程对待通信进程的单向访问,从而实现了待通信进程和目标进程之间的双向通信。
本发明实施例提供的跨进程通信的方法,与现有技术中的跨应用程序进程的通信方法,参数配置的复杂度较高,导致适用性较差,且可通信的数据承载量较低相比,其首先获取第一应用程序对应的待通信进程的第一标识号,然后基于该第一标识号建立目标进程与待通信进程之间的通信通道,其中,目标进程属于第二应用程序,第二应用程序和上述第一应用程序为终端的两个不同的应用程序,最后通过通信通道将待通信进程的访问请求发送至目标进程,以进行第一应用程序与第二应用程序的通信,其无需参数配置,操作简单,适用性较强,且基于第一标识号建立的通信通道实现高流量的数据承载,实用性较佳。
为了进一步保证通信的安全性和实时性,本发明实施例所提供的跨进程通信的方法在获取待通信进程的第一标识号之后,以及建立通信通道之前还建立了所有的应用进程及其对应的应用程序之间的映射关系,以便于根据该映射关系对通信通道是否建立进行先决条件(即应用是否启动)的判断,参见图2,具体通过如下步骤进行实现:
S201、获取终端的进程队列,进程队列为终端当前启用的所有应用进程的集合;
S202、对进程队列中的每个应用进程均提取对应的第二标识号;
S203、基于第二标识号获取应用进程对应的应用程序的包名;
S204、建立第二标识号和包名之间的映射关系。
具体的,本发明实施例所提供的跨进程通信的方法还建立了上述终端中已经开启的应用进程与对应的应用程序之间的映射关系,通过该关系,可以到应用程序正在进行的应用进程中,且能够获得该应用进程的标识号。
本发明实施例中在获取终端的进程队列之前首先获取了Android系统的当前的系统信息,即可以通过如下方式获取Android当前的进程队列:ActivityManagermActivityManager=
(ActivityManager)this.getSystemService(ACTIVITY_SERVICE);List<ActivityManager.RunningAppProcessInfo>mRunningProcess=mActivityManager.getRunningAppProcesses();上述进程队列是终端当前启用的所有应用进程的集合。在获取到进程队列后,本发明实施例将对该进程队列中的每个应用进程进行第二标识号的提取,并能够根据该第二标识号得到对应的应用程序的包名,其中,获取应用程序的包名具体通过如下方式:
通过使用一个for循环将该获取到的所有应用进程进行遍历,并将其中的每一项的应用包名和第二标识号(即进程pid)分别作为键值对存储到新建的map中(即建立了第二标识号和包名之间的映射关系),方便以后建立通讯的时候根据对应的应用包名查找对应的标识号。
另外,本发明实施例所提供的跨进程通信的方法在建立了上述映射关系后,将基于映射关系,判断第二应用程序是否获取到对应的目标进程的第三标识号,并能够在判断出第二应用程序获取到对应的第三标识号后,基于第一标识号建立目标进程与待通信进程之间的通信通道。
具体的,考虑到在Android系统开发时,已经通过协商的方式对一个应用程序可通信的其他应用程序进行了限定,本发明实施例中在获取到第二应用程序后,将基于上述映射关系,判断该第二应用程序是否获取到了对应的目标进程的第三标识号,如果已经获取到,则基于上述第一标识号进行目标进程与待通信进程之间的通信通道的建立;如果没有获取到第三标识号说明该对应的第二应用程序没有启动。在没有启动时,进程间的通讯是无法启动的。因此,如果出现通过包名找不到标识号的情况,则停止当前的进程间通讯的建立,并将其问题返回给第一应用程序。
考虑到socket在网络层的优良特性,本发明实施例所提供的跨进程通信的方法创新性的将socket通信应用到本地应用层中。参见图3,本发明实施例的上述通信通道的建立过程具体包括如下步骤:
S301、基于第一标识号对目标进程配置socket连接;
S302、基于socket连接建立目标进程与待通信进程之间的通信通道。
具体的,本发明实施例所提供的跨进程通信的方法通过如下方式进行socket连接:socket=new Socket();
socket.connect(new InetSocketAddress("127.0.0.1",pid),5000);
可见,本发明实施例优选的采用socket来进行通信连接,socket原本是网络层的一种通讯方式,而在本发明实施例中创新性的将该方式通过本地端口的不同而达到本地不同应用之间进行通讯的目的。Android系统中每个进程都会有一个对应的进程号,该进程号为该应用开启后在系统中的一个唯一标识,因此可以使用该号作为一个socket通讯的端口号,这样每个应用就不用去特意设置自己的唯一端口号了,而且也能保证该号不会重复。使用上述方法来达到建立socket连接的目的,pid为待通信进程的第一标识号。在建立上述socket后,将可以建立目标进程与待通信进程之间的通讯关系(通信通道)。
其中,本发明实施例可以通过如下具体方式实现第一应用程序向第二应用程序发送访问需求的功能:
OutputStream ou=socket.getOutputStream();
BufferedReader bff=New BufferedReader(new putStreamReader(socket.getInputStream()));
ou.write("android一个应用".getBytes("gbk"));
ou.flush();
通过和getInputStream和getOutputStream获取输入输出流,并通过ou.write向第二应用程序发送访问请求。
本发明实施例所提供的跨进程通信的方法在获取到待通信进程的第一标识号后,还将该第一标识号作为socket通信的端口号进行监听。其中,上述监听使用serverSocket来实现,在建立serverSocket中填入第一应用程序的第一标识号,并执行accept方法即可执行监听。该方法将在Android中建立在一个线程上,并不断循环来执行监听方法,用以达到实时监听第一应用程序与第二应用程序的通信的目的。如果在监听过程中有信息发送过来,则可以使用如下代码来实现:BufferedReaderbr=new BufferedReader(newInputStreamReader(s.getInputStream()));String mess=br.readLine()。
在不断的监听循环中,通过上述语句对mess进行判断,如果mess不为空,则断定有消息被接收,则开始读取该消息,如果mess为空,则判定没有接收到该消息,继续循环。
在第二应用程序接收到访问请求后,两者之间就可以开始真正的通讯了。在本发明实施例中每次发送消息都会带上第一应用程序的报名和pid,当接收方(第二应用程序)接收到该消息后同样可以建立新的socket来发送信息给发送方(第一应用程序)来实现通讯。
自此,进程间两个应用的通讯方式已经建立,而且本发明实施例中由于是手机中本地默认ip127.0.0.1来实现的,因此无论手机是否联网都可以使用,因此本发明实施例所提供的跨进程通信的方法不受网络的影响,适用性较强。
另外,本发明实施例还可以通过对socket连接执行close关闭第一应用程序和第二应用程序之间的通信。
本发明实施例提供的跨进程通信的方法,与现有技术中的跨应用程序进程的通信方法,参数配置的复杂度较高,导致适用性较差,且可通信的数据承载量较低相比,其首先获取第一应用程序对应的待通信进程的第一标识号,然后基于该第一标识号建立目标进程与待通信进程之间的通信通道,其中,目标进程属于第二应用程序,第二应用程序和上述第一应用程序为终端的两个不同的应用程序,最后通过通信通道将待通信进程的访问请求发送至目标进程,以进行第一应用程序与第二应用程序的通信,其无需参数配置,操作简单,适用性较强,且基于第一标识号建立的通信通道实现高流量的数据承载,实用性较佳。
本发明实施例还提供了一种跨进程通信的装置,所述装置用于执行上述跨进程通信的方法。参见图4,所述装置包括:
第一获取模块11,用于获取待通信进程的第一标识号,待通信进程属于第一应用程序;
第一建立模块22,用于基于第一标识号建立目标进程与待通信进程之间的通信通道,目标进程属于第二应用程序,第二应用程序和第一应用程序为终端的两个不同的应用程序;
通信模块33,用于通过通信通道将待通信进程的访问请求发送至目标进程,以进行第一应用程序与第二应用程序的通信。
进一步的,为了进一步保证通信的安全性和实时性,本发明实施例所提供的跨进程通信的装置还包括:
第二获取模块,用于获取终端的进程队列,进程队列为终端当前启用的所有应用进程的集合;
提取模块,用于对进程队列中的每个应用进程均提取对应的第二标识号;
第三获取模块,用于基于第二标识号获取应用进程对应的应用程序的包名;
第二建立模块,用于建立第二标识号和包名之间的映射关系。
具体的,本发明实施例所提供的跨进程通信的装置还建立了上述终端中已经开启的应用进程与对应的应用程序之间的映射关系,通过该关系,可以到应用程序正在进行的应用进程中,且能够获得该应用进程的标识号。
本发明实施例中在获取终端的进程队列之前首先获取了Android系统的当前的系统信息,即可以通过如下方式获取Android当前的进程队列:ActivityManagermActivityManager=
(ActivityManager)this.getSystemService(ACTIVITY_SERVICE);
List<ActivityManager.RunningAppProcessInfo>mRunningProcess=mActivityManager.getRunningAppProcesses();上述进程队列是终端当前启用的所有应用进程的集合。在获取到进程队列后,本发明实施例将对该进程队列中的每个应用进程进行第二标识号的提取,并能够根据该第二标识号得到对应的应用程序的包名,其中,获取应用程序的包名具体通过如下方式:
通过使用一个for循环将该获取到的所有应用进程进行遍历,并将其中的每一项的应用包名和第二标识号(即进程pid)分别作为键值对存储到新建的map中(即建立了第二标识号和包名之间的映射关系),方便以后建立通讯的时候根据对应的应用包名查找对应的标识号。
另外,本发明实施例所提供的跨进程通信的装置还包括判断模块,该判断模块,将基于映射关系,判断第二应用程序是否获取到对应的目标进程的第三标识号,另外,上述判断模块在判断出第二应用程序获取到对应的第三标识号后,将通过第一建立模块22基于第一标识号建立目标进程与待通信进程之间的通信通道。
具体的,考虑到在Android系统开发时,已经通过协商的方式对一个应用程序可通信的其他应用程序进行了限定,本发明实施例中在获取到第二应用程序后,将基于上述映射关系,判断该第二应用程序是否获取到了对应的目标进程的第三标识号,如果已经获取到,则基于上述第一标识号进行目标进程与待通信进程之间的通信通道的建立;如果没有获取到第三标识号说明该对应的第二应用程序没有启动。在没有启动时,进程间的通讯是无法启动的。因此,如果出现通过包名找不到标识号的情况,则停止当前的进程间通讯的建立,并将其问题返回给第一应用程序。
考虑到socket在网络层的优良特性,本发明实施例所提供的跨进程通信的装置创新性的将socket通信应用到本地应用层中。参见图5,本发明实施例中的第一建立模块22包括:
配置单元221,用于基于第一标识号对目标进程配置socket连接;
建立单元222,用于基于socket连接建立目标进程与待通信进程之间的通信通道。
具体的,本发明实施例所提供的跨进程通信的装置通过如下方式进行socket连接:socket=new Socket();
socket.connect(new InetSocketAddress("127.0.0.1",pid),5000);
可见,本发明实施例优选的采用socket来进行通信连接,socket原本是网络层的一种通讯方式,而在本发明实施例中创新性的将该方式通过本地端口的不同而达到本地不同应用之间进行通讯的目的。Android系统中每个进程都会有一个对应的进程号,该进程号为该应用开启后在系统中的一个唯一标识,因此可以使用该号作为一个socket通讯的端口号,这样每个应用就不用去特意设置自己的唯一端口号了,而且也能保证该号不会重复。使用上述方法来达到建立socket连接的目的,pid为待通信进程的第一标识号。在建立上述socket后,将可以建立目标进程与待通信进程之间的通讯关系(通信通道)。
其中,本发明实施例可以通过如下具体方式实现第一应用程序向第二应用程序发送访问需求的功能:
OutputStream ou=socket.getOutputStream();
BufferedReader bff=New BufferedReader(new putStreamReader(socket.getInputStream()));
ou.write("android一个应用".getBytes("gbk"));
ou.flush();
通过和getInputStream和getOutputStream获取输入输出流,并通过ou.write向第二应用程序发送访问请求。
本发明实施例所提供的跨进程通信的装置中的监听模块在获取到待通信进程的第一标识号后,还将该第一标识号作为socket通信的端口号进行监听。其中,上述监听使用serverSocket来实现,在建立serverSocket中填入第一应用程序的第一标识号,并执行accept方法即可执行监听。该方法将在Android中建立在一个线程上,并不断循环来执行监听方法,用以达到实时监听第一应用程序与第二应用程序的通信的目的。如果在监听过程中有信息发送过来,则可以使用如下代码来实现:BufferedReaderbr=newBufferedReader(new InputStreamReader(s.getInputStream()));String mess=br.readLine()。
在不断的监听循环中,通过上述语句对mess进行判断,如果mess不为空,则断定有消息被接收,则开始读取该消息,如果mess为空,则判定没有接收到该消息,继续循环。
在第二应用程序接收到访问请求后,两者之间就可以开始真正的通讯了。在本发明实施例中每次发送消息都会带上第一应用程序的报名和pid,当接收方(第二应用程序)接收到该消息后同样可以建立新的socket来发送信息给发送方(第一应用程序)来实现通讯。
自此,进程间两个应用的通讯方式已经建立,而且本发明实施例中由于是手机中本地默认ip127.0.0.1来实现的,因此无论手机是否联网都可以使用,因此本发明实施例所提供的跨进程通信的装置不受网络的影响,适用性较强。
另外,本发明实施例还可以通过对socket连接执行close关闭第一应用程序和第二应用程序之间的通信。
本发明实施例提供的跨进程通信的装置,与现有技术中的跨应用程序进程的通信方法,参数配置的复杂度较高,导致适用性较差,且可通信的数据承载量较低相比,其首先获取第一应用程序对应的待通信进程的第一标识号,然后基于该第一标识号建立目标进程与待通信进程之间的通信通道,其中,目标进程属于第二应用程序,第二应用程序和上述第一应用程序为终端的两个不同的应用程序,最后通过通信通道将待通信进程的访问请求发送至目标进程,以进行第一应用程序与第二应用程序的通信,其无需参数配置,操作简单,适用性较强,且基于第一标识号建立的通信通道实现高流量的数据承载,实用性较佳。
本发明实施例所提供的进行跨进程通信的方法的计算机程序产品,包括存储了程序代码的计算机可读存储介质,所述程序代码包括的指令可用于执行前面方法实施例中所述的方法,具体实现可参见方法实施例,在此不再赘述。
本发明实施例所提供的跨进程通信的装置可以为设备上的特定硬件或者安装于设备上的软件或固件等。本发明实施例所提供的装置,其实现原理及产生的技术效果和前述方法实施例相同,为简要描述,装置实施例部分未提及之处,可参考前述方法实施例中相应内容。所属领域的技术人员可以清楚地了解到,为描述的方便和简洁,前述描述的系统、装置和单元的具体工作过程,均可以参考上述方法实施例中的对应过程,在此不再赘述。
在本发明所提供的实施例中,应该理解到,所揭露装置和方法,可以通过其它的方式实现。以上所描述的装置实施例仅仅是示意性的,例如,所述单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,又例如,多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些通信接口,装置或单元的间接耦合或通信连接,可以是电性,机械或其它的形式。
所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
另外,在本发明提供的实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。
所述功能如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本发明各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:U盘、移动硬盘、只读存储器(ROM,Read-Only Memory)、随机存取存储器(RAM,Random Access Memory)、磁碟或者光盘等各种可以存储程序代码的介质。
应注意到:相似的标号和字母在下面的附图中表示类似项,因此,一旦某一项在一个附图中被定义,则在随后的附图中不需要对其进行进一步定义和解释,此外,术语“第一”、“第二”、“第三”等仅用于区分描述,而不能理解为指示或暗示相对重要性。
最后应说明的是:以上所述实施例,仅为本发明的具体实施方式,用以说明本发明的技术方案,而非对其限制,本发明的保护范围并不局限于此,尽管参照前述实施例对本发明进行了详细的说明,本领域的普通技术人员应当理解:任何熟悉本技术领域的技术人员在本发明揭露的技术范围内,其依然可以对前述实施例所记载的技术方案进行修改或可轻易想到变化,或者对其中部分技术特征进行等同替换;而这些修改、变化或者替换,并不使相应技术方案的本质脱离本发明实施例技术方案的精神和范围。都应涵盖在本发明的保护范围之内。因此,本发明的保护范围应所述以权利要求的保护范围为准。

Claims (10)

1.一种跨进程通信的方法,其特征在于,包括:
获取待通信进程的第一标识号,所述待通信进程属于第一应用程序;
基于所述第一标识号建立目标进程与所述待通信进程之间的通信通道,所述目标进程属于第二应用程序,所述第二应用程序和所述第一应用程序为终端的两个不同的应用程序;
通过所述通信通道将所述待通信进程的访问请求发送至所述目标进程,以进行所述第一应用程序与所述第二应用程序的通信。
2.根据权利要求1所述的方法,其特征在于,所述获取待通信进程的第一标识号和所述基于所述第一标识号建立目标进程与所述待通信进程之间的通信通道之间,包括:
获取所述终端的进程队列,所述进程队列为所述终端当前启用的所有应用进程的集合;
对所述进程队列中的每个所述应用进程均提取对应的第二标识号;
基于所述第二标识号获取所述应用进程对应的应用程序的包名;
建立所述第二标识号和所述包名之间的映射关系。
3.根据权利要求2所述的方法,其特征在于,所述建立所述第二标识号和所述包名之间的映射关系之后,包括:
基于所述映射关系,判断所述第二应用程序是否获取到对应的目标进程的第三标识号;
所述基于所述第一标识号建立目标进程与所述待通信进程之间的通信通道,包括:
在判断出所述第二应用程序获取到对应的所述第三标识号后,基于所述第一标识号建立目标进程与所述待通信进程之间的通信通道。
4.根据权利要求1或3所述的方法,其特征在于,所述基于所述第一标识号建立目标进程与所述待通信进程之间的通信通道,包括:
基于所述第一标识号对所述目标进程配置socket连接;基于所述socket连接建立所述目标进程与所述待通信进程之间的通信通道。
5.根据权利要求1所述的方法,其特征在于,还包括:
基于所述第一标识号对所述第一应用程序与所述第二应用程序的通信进行实时监听,以判断所述目标进程是否已经接收所述待通信进程的所述访问请求。
6.一种跨进程通信的装置,其特征在于,包括:
第一获取模块,用于获取待通信进程的第一标识号,所述待通信进程属于第一应用程序;
第一建立模块,用于基于所述第一标识号建立目标进程与所述待通信进程之间的通信通道,所述目标进程属于第二应用程序,所述第二应用程序和所述第一应用程序为终端的两个不同的应用程序;
通信模块,用于通过所述通信通道将所述待通信进程的访问请求发送至所述目标进程,以进行所述第一应用程序与所述第二应用程序的通信。
7.根据权利要求6所述的装置,其特征在于,还包括:
第二获取模块,用于获取所述终端的进程队列,所述进程队列为所述终端当前启用的所有应用进程的集合;
提取模块,用于对所述进程队列中的每个所述应用进程均提取对应的第二标识号;
第三获取模块,用于基于所述第二标识号获取所述应用进程对应的应用程序的包名;
第二建立模块,用于建立所述第二标识号和所述包名之间的映射关系。
8.根据权利要求7所述的装置,其特征在于,还包括判断模块;
所述判断模块,用于基于所述映射关系,判断所述第二应用程序是否获取到对应的目标进程的第三标识号;
所述第一建立模块,还用于在判断出所述第二应用程序获取到对应的所述第三标识号后,基于所述第一标识号建立目标进程与所述待通信进程之间的通信通道。
9.根据权利要求6或8所述的装置,其特征在于,所述第一建立模块包括:
配置单元,用于基于所述第一标识号对所述目标进程配置socket连接;
建立单元,用于基于所述socket连接建立所述目标进程与所述待通信进程之间的通信通道。
10.根据权利要求6所述的装置,其特征在于,还包括监听模块;
所述监听模块,用于基于所述第一标识号对所述第一应用程序与所述第二应用程序的通信进行实时监听,以判断所述目标进程是否已经接收所述待通信进程的所述访问请求。
CN201611058913.4A 2016-11-28 2016-11-28 一种跨进程通信的方法及装置 Active CN106547634B (zh)

Priority Applications (2)

Application Number Priority Date Filing Date Title
CN201611058913.4A CN106547634B (zh) 2016-11-28 2016-11-28 一种跨进程通信的方法及装置
PCT/CN2017/079614 WO2018094951A1 (zh) 2016-11-28 2017-04-06 一种跨进程通信的方法、装置及可读取存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201611058913.4A CN106547634B (zh) 2016-11-28 2016-11-28 一种跨进程通信的方法及装置

Publications (2)

Publication Number Publication Date
CN106547634A true CN106547634A (zh) 2017-03-29
CN106547634B CN106547634B (zh) 2020-07-31

Family

ID=58395970

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201611058913.4A Active CN106547634B (zh) 2016-11-28 2016-11-28 一种跨进程通信的方法及装置

Country Status (2)

Country Link
CN (1) CN106547634B (zh)
WO (1) WO2018094951A1 (zh)

Cited By (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106961482A (zh) * 2017-04-01 2017-07-18 联想(北京)有限公司 一种信息处理方法及装置、存储介质、电子设备
CN107833614A (zh) * 2017-10-26 2018-03-23 咪咕互动娱乐有限公司 一种能量监控方法、装置和存储介质
WO2018094951A1 (zh) * 2016-11-28 2018-05-31 武汉斗鱼网络科技有限公司 一种跨进程通信的方法、装置及可读取存储介质
CN110569130A (zh) * 2019-07-29 2019-12-13 华为技术有限公司 一种跨进程通信方法、装置及设备
CN111385265A (zh) * 2018-12-29 2020-07-07 北京奇虎科技有限公司 一种iOS系统中的通信方法和装置
CN114615546A (zh) * 2022-02-08 2022-06-10 武汉光庭信息技术股份有限公司 一种视频播放方法、装置、电子设备及存储介质
CN114827154A (zh) * 2021-01-18 2022-07-29 网宿科技股份有限公司 一种端口监听方法、系统及服务器
CN116709609A (zh) * 2022-09-30 2023-09-05 荣耀终端有限公司 消息传递方法、电子设备及存储介质

Families Citing this family (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111158935B (zh) * 2019-12-31 2023-07-25 北京奇艺世纪科技有限公司 一种应用程序检测方法、装置、计算机设备及存储介质
CN113032038B (zh) * 2021-02-25 2022-05-03 武汉深之度科技有限公司 一种应用程序管理方法、装置、计算设备及可读存储介质
CN113825124A (zh) * 2021-08-20 2021-12-21 福建魔方电子科技有限公司 一种Android平台上本机扩展硬件设备的蓝牙通讯方法及装置

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103455380A (zh) * 2012-06-05 2013-12-18 上海斐讯数据通信技术有限公司 多进程通信系统及其建立和通信方法
CN104809046A (zh) * 2015-05-27 2015-07-29 广东欧珀移动通信有限公司 一种应用程序联网控制方法和应用程序联网控制装置
CN104869569A (zh) * 2015-03-31 2015-08-26 小米科技有限责任公司 应用程序的网络权限控制方法及装置
WO2015188330A1 (zh) * 2014-06-11 2015-12-17 华为技术有限公司 多内核操作系统进程处理方法及装置
CN105579969A (zh) * 2013-09-23 2016-05-11 三星电子株式会社 用于在应用程序之间进行设备特定的通信的方法和装置

Family Cites Families (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102340410B (zh) * 2010-07-21 2014-09-10 中兴通讯股份有限公司 集群管理系统及方法
CN106547634B (zh) * 2016-11-28 2020-07-31 武汉斗鱼网络科技有限公司 一种跨进程通信的方法及装置

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103455380A (zh) * 2012-06-05 2013-12-18 上海斐讯数据通信技术有限公司 多进程通信系统及其建立和通信方法
CN105579969A (zh) * 2013-09-23 2016-05-11 三星电子株式会社 用于在应用程序之间进行设备特定的通信的方法和装置
WO2015188330A1 (zh) * 2014-06-11 2015-12-17 华为技术有限公司 多内核操作系统进程处理方法及装置
CN104869569A (zh) * 2015-03-31 2015-08-26 小米科技有限责任公司 应用程序的网络权限控制方法及装置
CN104809046A (zh) * 2015-05-27 2015-07-29 广东欧珀移动通信有限公司 一种应用程序联网控制方法和应用程序联网控制装置

Cited By (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2018094951A1 (zh) * 2016-11-28 2018-05-31 武汉斗鱼网络科技有限公司 一种跨进程通信的方法、装置及可读取存储介质
CN106961482A (zh) * 2017-04-01 2017-07-18 联想(北京)有限公司 一种信息处理方法及装置、存储介质、电子设备
CN107833614A (zh) * 2017-10-26 2018-03-23 咪咕互动娱乐有限公司 一种能量监控方法、装置和存储介质
CN111385265A (zh) * 2018-12-29 2020-07-07 北京奇虎科技有限公司 一种iOS系统中的通信方法和装置
CN110569130A (zh) * 2019-07-29 2019-12-13 华为技术有限公司 一种跨进程通信方法、装置及设备
CN110569130B (zh) * 2019-07-29 2021-12-14 华为技术有限公司 一种跨进程通信方法、装置及设备
US11853820B2 (en) 2019-07-29 2023-12-26 Huawei Technologies Co., Ltd. Cross-process communication method, apparatus, and device
CN114827154A (zh) * 2021-01-18 2022-07-29 网宿科技股份有限公司 一种端口监听方法、系统及服务器
CN114615546A (zh) * 2022-02-08 2022-06-10 武汉光庭信息技术股份有限公司 一种视频播放方法、装置、电子设备及存储介质
CN114615546B (zh) * 2022-02-08 2024-04-12 武汉光庭信息技术股份有限公司 一种视频播放方法、装置、电子设备及存储介质
CN116709609A (zh) * 2022-09-30 2023-09-05 荣耀终端有限公司 消息传递方法、电子设备及存储介质
CN116709609B (zh) * 2022-09-30 2024-05-14 荣耀终端有限公司 消息传递方法、电子设备及存储介质

Also Published As

Publication number Publication date
WO2018094951A1 (zh) 2018-05-31
CN106547634B (zh) 2020-07-31

Similar Documents

Publication Publication Date Title
CN106547634A (zh) 一种跨进程通信的方法及装置
CN104468731B (zh) 违章停车提示方法和系统
EP3796188A1 (en) Blockchain network transaction processing method, apparatus, device, and storage medium
CN104144106B (zh) 一种消息转发方法、装置及系统
CN103209247B (zh) 一种信息显示的方法和系统以及终端和服务器
EP3016296A1 (en) Bluetooth communication method and bluetooth communication device
CN103605529B (zh) 应用程序的处理方法和装置
CN107612661A (zh) 数据通讯方法和装置
CN103716356B (zh) 基于web的存储过程操作方法、装置和系统
CN107730955A (zh) 基于电子车牌的反向寻车方法及装置
CN110430198A (zh) 身份验证方法、边缘服务器,和购物管理方法及系统
CN109981360A (zh) 物联网设备站点开通方法、装置、系统及存储介质
CN102752327A (zh) 一种终端与云端服务器进行交互的方法、系统及装置
CN103458004A (zh) 物联网设备签约信息变更方法和设备
CN104618507A (zh) 一种车联网环境下的社交生态组织管理系统及其方法
CN109640373A (zh) 一种应用于物联网的组网方法、装置和存储介质
CN106856585A (zh) 建立短距离无线通道的方法及装置
CN104244410A (zh) 一种定位方法及定位系统
CN102209396B (zh) 终端设备在网络中附着的方法、网元设备及网络系统
CN109218370A (zh) 消息发送方法及装置、电子设备
CN104753761A (zh) 消息的处理方法、服务器及系统
CN108183978A (zh) 一种通信设备ip地址配置方法及通信设备
CN103067503A (zh) 一种实现应用同步的方法、装置及系统
CN106060925B (zh) 智能网关分布确定方法和智能网关
CN105246125B (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
TR01 Transfer of patent right

Effective date of registration: 20240528

Address after: 100000 616, floor 6, 33 Suzhou street, Haidian District, Beijing

Patentee after: Baosheng (China) Technology Industry Co.,Ltd.

Country or region after: China

Address before: 430000 East Lake Development Zone, Wuhan City, Hubei Province, No. 1 Software Park East Road 4.1 Phase B1 Building 11 Building

Patentee before: WUHAN DOUYU NETWORK TECHNOLOGY Co.,Ltd.

Country or region before: China

TR01 Transfer of patent right