IPC 机制(开发艺术探索)

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

适用场景

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/weixin_43910395/article/details/84713683