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

适用场景

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值