IPC 机制
**IPC:**Inter-Process Communication的缩写,跨进程通信
使用场景:
1.分配更大的内存空间
2.防止进程被杀死
3.为至进程分担压力
使用时需注意的问题:
1.静态成员和单例模式完全失效(不是同一块内存,会产生不同的副本)
2.线程同步机制完全失效(不是同一块内存,所以对象也不是同一个,因此类锁、对象锁也不是同一个,不能保证线程同步)
3.SharedPreferences 可靠性下降(SharedPreferences不支持多个进程同时写,会有一定的几率丢失数据)
4.Application 多次创建(Android为每个进程分配独立的虚拟机,这个过程其实就是启动一个应用,所以Application会被创建多次),所以我们不能直接将一些数据保存在Application中。
使用方法:
1.四大组件在AndroidMenifest中指定android:process属性
2.JNI层面上去fork一个新的进程
原理:
进程间,用户空间的数据不可共享,所以用户空间 = 不可共享空间
进程间,内核空间的数据可共享,所以内核空间 = 可共享空间
先通过 进程间 的内核空间进行 数据交互,再通过 进程内 的用户空间 & 内核空间进行 数据交互,从而实现 进程间的用户空间 的数据交互
基础知识:
序列化:Serializable(持久化) Paecelable(序列化)
Serializable:java 自带的接口,使用简单但开销大
Paecelable: Android 中序列化的方式,效率相对较高
区别:Parcelable 主要用于IPC中的序列化(内存序列化),Serializable在Android中更偏持久化的含义,在序列化到存储设备、网络传输方面,更优秀
通信方式(待完善)
Bundle
共享文件
Messenger
AIDL
ContentProvider
Socket