-
如何实现进程共享
- 时间:2024-11-23 09:31:51
大家好,今天Win10系统之家小编给大家分享「如何实现进程共享」的知识,如果能碰巧解决你现在面临的问题,记得收藏本站或分享给你的好友们哟~,现在开始吧!
1.java 怎样实现进程间数据源的共享使
JAVA进程间通信的方法主要有以下几种:
(1)管道(Pipe):管道可用于具有亲缘关系进程间的通信,允许一个进程和另一个与它有共同祖先的进程之间进行通信。
(2)命名管道(named pipe):命名管道克服了管道没有名字的限制,除具有管道所具有的功能外,它还允许无亲缘关系进程间的通信。
(3)信号(Signal):信号是比较复杂的通信方式,用于通知接受进程有某种事件发生,除了用于进程间通信外,进程还可以发送 信号给进程本身。
(4)消息(Message)队列:消息队列是消息的链接表,包括Posix消息队列system V消息队列。
(5)共享内存:使得多个进程可以访问同一块内存空间,是最快的可用IPC形式。是针对其他通信机制运行效率较低而设计的。
(6)内存映射(mapped memory):内存映射允许任何多个进程间通信,每一个使用该机制的进程通过把一个共享的文件映射到自己的进程地址空间来实现它。
(7)信号量(semaphore):主要作为进程间以及同一进程不同线程之间的同步手段。
(8)套接口(Socket):更为一般的进程间通信机制,可用于不同机器之间的进程间通信。
2.如何实现多个APK间共享一个进程
默认情况下,同一个应用程序中的所有组件运行在同一个进程中,而且绝大多数的应用程序也都是这样的。但是,如果我们想要控制让某个特定的组件属于某个进程,我们可以在manifest文件中进行配置。
在每种组件元素(activity、service、receiver、provider)的manifest条目中,都支持一个“android:process”的属性,通过这个属性,我们可以指定某个组件运行的进程。我们可以通过设置这个属性,让每个组件运行在它自己的进程中,也可以只让某些组件共享一个进程。我们要可以通过设置“android:process”属性,让不同应用程序中的组件运行在相同的进程中,这些应用程序共享相同的Linux用户ID,拥有相同的证书。
<application>元素也有一个“android:process”属性,可以设置一个应用于全部组件的默认值。
当可用内存数量低,而一些与用户即时交互的进程又需要内存时,Android随时可能会终止某个进程。运行在被终止的进程中的组件会因此被销毁,但是,当再次需要这些组件工作时,就会再启动一个进程。
在决定要终止哪个进程时,Android系统会权衡它们对于用户的重要性。例如,相较于运行可见activities的进程,终止一个运行不可见activities的进程会更加合理。是否终止一个进程,依赖于运行在这个进程中的组件的状态。
如果不能将两个activity放入同一个application中的话,可以通过在各自的manifest中设置以下属性,让这两个activity强制运行在同一个进程中,从而可以充分利用进程内共享的资源,减少内存占用:
Java代码:
1.(1)设置相同的User Id:
2.<manifest android:sharedUserId="aaa.bbb"
3.(2)被调用的activity设置以下属性:
4.<activity android:multiprocess="true"
5.或者
6.<activity android:process="com.cienet.test"
对于3D OpenGL程序,修改以上属性后,被调用的activity的内存占用会明显减少,比如:30MB -> 2MB。
可以做如下测试如何共享一个进程
Java代码:
1.加入android:sharedUserId="aaa.bbb"没有
2.android:process="com.cienet.test"
3.07-12 15:42:34.781: ERROR/Dean(7615): Binder.getCallingPid()7615
4.07-12 15:42:34.785: ERROR/Dean(7615): runningappprocessinfo.pid:7615runningappprocessinfo.processNamecom.cienet.testa
5.07-12 15:42:34.785: ERROR/Dean(7615): pkgname:7615:com.cienet.testa
6.
7.
8.07-12 15:42:24.722: ERROR/Dean(7602): Binder.getCallingPid()7602
9.07-12 15:42:24.726: ERROR/Dean(7602): runningappprocessinfo.pid:7602runningappprocessinfo.processNamecom.cienet.testb
10.07-12 15:42:24.726: ERROR/Dean(7602): pkgname:7602:com.cienet.testb
11.
12.加入android:process="com.cienet.test"到B
13.
14.07-12 15:46:41.933: ERROR/Dean(7738): Binder.getCallingPid()7738
15.07-12 15:46:41.937: ERROR/Dean(7738): runningappprocessinfo.pid:7738runningappprocessinfo.processNamecom.cienet.test
16.07-12 15:46:41.937: ERROR/Dean(7738): pkgname:7738:com.cienet.testb
17.
18.07-12 15:47:13.246: ERROR/Dean(7761): Binder.getCallingPid()7761
19.07-12 15:47:13.246: ERROR/Dean(7761): runningappprocessinfo.pid:7761runningappprocessinfo.processNamecom.cienet.testa
20.07-12 15:47:13.250: ERROR/Dean(7761): pkgname:7761:com.cienet.testa
21.
22.同时加入android:process="com.cienet.test"到A
23.
24.07-12 15:50:24.988: ERROR/Dean(7878): getApplicationInfo:publicSourceDir/data/app/com.cienet.testa-1.apk
25.07-12 15:50:24.988: ERROR/Dean(7878): getApplicationInfo:descriptionRes0
26.07-12 15:50:24.988: ERROR/Dean(7878): Binder.getCallingPid()7878
27.07-12 15:50:24.992: ERROR/Dean(7878): runningappprocessinfo.pid:7878runningappprocessinfo.processNamecom.cienet.test
28.07-12 15:50:24.992: ERROR/Dean(7878): pkgname:7878:com.cienet.testa
29.
30.
31.07-12 15:50:46.964: ERROR/Dean(7878): getApplicationInfo:publicSourceDir/data/app/com.cienet.testb-1.apk
32.07-12 15:50:46.964: ERROR/Dean(7878): getApplicationInfo:descriptionRes0
33.07-12 15:50:46.964: ERROR/Dean(7878): Binder.getCallingPid()7878
34.07-12 15:50:46.968: ERROR/Dean(7878): runningappprocessinfo.pid:7878runningappprocessinfo.processNamecom.cienet.test
35.07-12 15:50:46.972: ERROR/Dean(7878): pkgname:7878:com.cienet.testa
36.
37.
38.去掉android:sharedUserId="aaa.bbb"
39.07-12 15:52:29.574: ERROR/Dean(7967): getApplicationInfo:publicSourceDir/data/app/com.cienet.testb-2.apk
40.07-12 15:52:29.578: ERROR/Dean(7967): getApplicationInfo:descriptionRes0
41.07-12 15:52:29.578: ERROR/Dean(7967): Binder.getCallingPid()7967
42.07-12 15:52:29.578: ERROR/Dean(7967): runningappprocessinfo.pid:7967runningappprocessinfo.processNamecom.cienet.test
43.07-12 15:52:29.578: ERROR/Dean(7967): pkgname:7967:com.cienet.testb
44.
45.
46.07-12 15:53:06.730: ERROR/Dean(7990): getApplicationInfo:publicSourceDir/data/app/com.cienet.testa-2.apk
47.07-12 15:53:06.730: ERROR/Dean(7990): getApplicationInfo:descriptionRes0
48.07-12 15:53:06.730: ERROR/Dean(7990): Binder.getCallingPid()7990
49.07-12 15:53:06.734: ERROR/Dean(7990): runningappprocessinfo.pid:7990runningappprocessinfo.processNamecom.cienet.test
50.07-12 15:53:06.734: ERROR/Dean(7990): pkgname:7990:com.cienet.testa
如上证明那个APK共享进程要两个条件(1)设置相同的User Id:
(2)被调用的activity设置以下属性:
<activity android:multiprocess="true"
或者
<activity android:process="com.cienet.test"
3.LINUX下系统编程,多进程间数据共享,即共享变量
共享内存相关的API怎么使用不难:
1. 首先调用shmget分配一个新的共享内存,这里你可以指定其大小,如果你要分配一个整形,那你可以将size参数设置成4,如果你要共享一个结构体那就将size参数设置成你的结构体大小,操作系统不关心你要共享什么,它只关心你要分配多少个字节的区间。而且实际上操作系统会将你要求的大小按照内存页面的大小进行对齐,也就是说它可能实际上给你分配若干个页面的物理存储空间,只要这个空间能够容纳你所指定的大小就ok了。它的第三个参数是关于一些访问权限设置的,要讲起来太长,建议自己搜索一下,或者用man查查帮助。总之,调用完shmget以后系统会给你创建一段共享内存,然后返回给你一个shmid,也就是这个共享内存的标识,你可以理解为给它取了个名字。
2. 接着调用shmat将这段共享内存映射到你的进程的虚拟地址空间上。这个函数的第一个参数就是你之前调用shmget创建的共享内存的名字shmid;第二个参数是个指针,指向你的进程虚存空间中的某个地址,你可以通过传入一个确定的地址强行要求操作系统将共享内存映射到你指定的虚存地址上(可能会失败,如果你指定的虚拟地址空间已经映射了别的物理存储空间),也可以通过传入0地址让系统给你选择一个合适的地址(它会通过返回值把地址返回给你)。第三个参数则允许你指定一些特殊的标志位,还是那句话,太复杂自己搜索一下看看,一般应用不需要用到。
至于例子嘛你可以看看下面这个链接:
另外,你要知道只用共享内存是不互斥的,你必须结合信号量一起使用才能防止互斥问题的出现。如果你共享的只是一个整形变量可能问题不大,因为对页面对齐的整形变量的读写都是原子操作,但如果你共享的是个复杂的结构体就得小心了。
以上就是关于「如何实现进程共享」的全部内容,本文讲解到这里啦,希望对大家有所帮助。如果你还想了解更多这方面的信息,记得收藏关注本站~
本①文*来源Win10系统之家www.ghost580.net,转载请注明出处!
相关文章
-
1.java怎样实现进程间数据源的共享使JAVA进程间通信的方法主要有以下几种:(1)管道(Pipe):管道可用于具有亲缘关系进程间的通信,允许一个进程和另一个与它有共同祖先的进程之间进行通信。(2)命名管道(namedpipe):命名...
-
1.文件怎么实现共享的?首先,这里不考虑物理联接和其它问题,只谈及策略问题。此外,请安装相应的协议并正确的设置IP地址,同时尽量把计算机设置在一个工作组内且具有相同网段的IP地址。其次,网上对于出现的问题描述较多,...
-
1.怎样设置打印机共享?步骤1:将打印机连接到主机,打开打印机电源,通过主机的“控制面板”进入“打印机和传真”文件夹,在空白处单击鼠标右键,选择“添加打印机”命令,打开添加打印机的向导窗口。选择“连接到这台计算机的本...
-
1.win7系统怎么取消粘滞键避免干扰游戏进程win7系统自带不断成熟,自带很多小功能,这里小编向大家介绍粘滞键,其实粘滞键算是win7系统比较人性化的设计了,它可以帮助那些不喜欢同时按下两个键或者是多个键的朋友省去...