IPC 简说
IPC(inter-process communication)进程间通信
多进程分为两种情况
1. 同一个应用,使用android:process属性启动的四大组件
2. 多应用
通过android:process启动进程的方式
1. 默认:进程名为当前进程包名
2. : + 名字 :进程名为当前进程包名 + 名字 (私有进程)
3. 字符串:进程名为 字符串(全局进程)
多进程运行机制
1. 静态成员和单例模式完全失效
不同进程,虚拟机存储区域不同
2. 线程同步机制完全失效
不在同一块内存上,锁的也不是同一个对象
3. SharedPreferences可靠性下降
本质是在文件里读写,并发读写会有问题
4. Application会多次创建
IPC基础概念:主要包括Serializable [ˈsɪərɪəlaɪz]接口(连载,使连续),Parcelable['pɑːs(ə)l]接口(包裹,小包),Binder(装订工;捆缚者)
Serializable与Parcelable都是序列化接口,Serializable是java序列化话接口,使用简单,系统开销大。Parcelable是android序列化接口,使用麻烦些,但效率高。
序列化与反序列化:进程A数据序列化后,进程B反序列化成自己能用的数据,进程B数据序列化后,进程A再反序列化成自己能用的数据,达到数据共同的作用。序列化是将数据写到媒介中(文本,媒体等),反序列化是读取的过程。两边通过一定的协议达到数据共同的作用。
Binder在android中是一种跨进程的通讯方式,是客户端与服务端的通讯媒介。
可以通过AIDL来分析Binder的工作机制:
Book.java
public class Book implements Parcelable{...}
Book.aidl
package com.***.***
parcelable Book;
IBookManager.aidl
package com.***.***
interface IBookManager{...}
生成.java文件,代码分为两部分。
1. 声明一个AIDL性质的接口,只需要继承IInterface接口
public interface IBookManager extends IInterface{}
2. 实现Stub和Stub类中的Proxy代理类
public class BookManagerImpl extends Binder implements IBookManager{
private static class Proxy implements IBookManager{}
}
Binder两个很重要的方法linkToDeath和unlinkToDeath,死亡代理,客户端到服务端的Binder连接可能断开,为了不影响两端功能,Binder提供这两个方法,让Binder死亡时,可以收到消息并重新连接。
private IBinder.DeathRecipient mDeathRecipient = new IBinder.DeathRecipitent(){
@Override
public void binderDied(){
....
mBookManager.asBinder().unlinkToDeath(mDeathRecipient, 0);
.... // 重新绑定服务
}
}
在客户端绑定服务成功后,给binder设置死亡代理
binder.linkToDeath(mDeathRecipient, 0);
Android中的IPC方式
1.使用Bundler实现IPC
ASB三大组件都可以通过intent的Bundler传值,因为Bundler实现了Parcelable接口
2.使用文件共享
通过文件共享方式是有局限性的,比如并发读、写的问题。
SharedPreferences是Android中提供的轻量级缓存方案,实际上采用xml文件来存储键值对的,系统对它有缓存策略,对高并发的读写,有很大几率会丢失数据。
3. 使用Messenger
messenger可以翻译成信使,在不同进程中传递Message对象。messenger底层是AIDL。可以像AIDL那样使用。
服务端,创建Handler对象,用它创建一个Messenger对象,在service中的onBind方法中返回这个Messenger对像的底层Binder即可。
客户端,绑定服务后,获取IBinder对象创建Messenger,通过这个Messenger就可以向服务端发送消息了。
如果需要服务端能够回复客户端,就和服务端一样,创建Handler并创建一个新的Messenger,把这个Messenger通过Message的replyTo参数传递给服务端,服务端通过这个replyTo参数就能回应客户端了。
4. 使用AIDL
值得注意的:RemoteCallbackList来存储客户端注册进来的回调接口。客户端在onDestory中去解除注册到服务端的listener,服务端竟然找不到之前注册的那个listener。系统就提供专门的容器来解决这个问题:RemoteCallbackList。
5. ContentProvider
是Android专门用来多应用间数据共享的和Messenger一样底层同样是Binder,使用上比AIDL简单多了。
自定义ContentProvider,集成ContentProvider并且实现它的六个方法onCreate,query,updatae,insert,getType。
需要配合数据库来完成数据共享
class MyContentProvider extends ContentProvider{}
...getContentResolover().query(uri,...)
6. 使用Socket
IPC 简说的更多相关文章
- unix domain IPC 进程间通信简析
Linux系统有多种进程间通信方式,如信号.消息队列.管道等,socket是其中一种,socket使用unix domain 模式进行进程间通信 //服务端代码 #include <stdio. ...
- TaintDroid剖析之IPC级污点传播
TaintDroid剖析之IPC级污点传播 作者:简行.走位@阿里聚安全 前言 在前三篇文章中我们详细分析了TaintDroid对DVM栈帧的修改,以及它是如何在修改之后的栈帧中实现DVM变量级污点跟 ...
- 浅谈Android系统进程间通信(IPC)机制Binder中的Server和Client获得Service Manager接口之路
文章转载至CSDN社区罗升阳的安卓之旅,原文地址:http://blog.csdn.net/luoshengyang/article/details/6627260 在前面一篇文章浅谈Service ...
- System V IPC 之消息队列
消息队列和共享内存.信号量一样,同属 System V IPC 通信机制.消息队列是一系列连续排列的消息,保存在内核中,通过消息队列的引用标识符来访问.使用消息队列的好处是对每个消息指定了特定消息类型 ...
- 进程间通信IPC (InterProcess Communication)
一.进程间通信的概念 每个进程各自有不同的用户地址空间,任何一个进程的全局变量在另一个进程中都看不到,所以进程之间要交换数据必须通过内核,在内核中开辟一块缓冲区,进程1把数据从用户空间拷到内核缓冲区, ...
- Binder机制简析(三)
注册Service Service组件运行在Server进程中,首先要将Service注册到Service Manager中,再启动一个Binder线程池来等待和处理Client的通信请求. 注册过程 ...
- 极简 Node.js 入门 - 2.3 process
极简 Node.js 入门系列教程:https://www.yuque.com/sunluyong/node 本文更佳阅读体验:https://www.yuque.com/sunluyong/node ...
- Android之使用Bundle进行IPC
一.Bundle进行IPC介绍 四大组件中的三大组件(Activity.Service.Receiver)都是支持在Intent中传递Bundle数据的,由于Bundle实现了Parcelable接口 ...
- Android之使用文件进行IPC
一.文件进行IPC介绍 共享文件也是一种不错的进程间通信方式,两个进程通过读/写同一个文件来交换数据.在Windows上,一个文件如果被加了排斥锁将会导致其他线程无法对其进行访问,包括读写,而由于An ...
随机推荐
- 使用Microsoft SyncToy 文件同步/备份 自动化处理
SyncToy 是由 微软 推出的一款免费的文件夹同步工具.百度搜索Microsoft SyncToy,官网可以直接下载 安装完成后 操作也非常简单,主要有三种模式 synchronize :在这个模 ...
- 远程桌面控制winsever,复制文件或者文件夹夹时出错提示“未指定的错误” 二(如何让远程电脑识别U盘)
一.背景: 要给远程服务器安装数据库,把安装复制到服务器,出现复制文件或者文件夹夹时出错提示“未指定的错误”:通过映射网络分享文件方法来解决,发现服务器访问网络出现错误,ping分享文件电脑的IP ...
- jemter分布式部署及linux下分布式脚本执行
jmeter进行接口性能测试,占用内存较大,在模拟千万计并发用户时,使用分布式部署进行分压测试. 操作步骤:选择一台机器作为调度机,其他机器作为执行机 一.jmeter分布式部署 前提条件:A.执行机 ...
- ibatis项目应用
创建数据库表: create table u_student( student_id number 16, student_name varchar2(108), student_code numbe ...
- restore和recover的区别
restore 是还原物理文件 recover 是用日志恢复到一致 用了RMAN备份后就必须要用restore还原,然后才用recover恢复 restore——还原,与backup相对,从备份读出恢 ...
- C# 今天时间 今天结束时间
var startTime = DateTime.UtcNow.ToString(timeFormat); ).AddSeconds(-).ToUniversalTime().ToString(tim ...
- git之我常用的命令
撤销修改: git checkout -- file 撤销暂存区: git reset HEAD git reset HEAD file 撤销版本库:git reset --hard HEAD^回到上 ...
- Nginx 作用
django 请求的生命周期 Nginx 的作用: 浏览器 --- nginx(反向代理器)-- uwsgi --- django项目nginx : 负载均衡, 将任务分发给不同的uwsgi 动静分离 ...
- idea springboot jrebel hotreloaded
http://127.0.0.1:8888/88414687-3b91-4286-89ba-2dc813b107ce
- php遍历数组7种方式(严格说是五种)
数组: $arr = array(1,2,3,4,5); 第一种:foreach (最常见的) foreach ($arr as $v){ echo $v;} 第二种:for for($i=0;$i& ...