进程隔离是为保护操做系统中进程互不干扰而设计的一组不一样硬件和软件的技术。进程数据不共享,进程A的虚拟地址和进程B的虚拟地址不一样,这样就防止进程A将数据信息写入进程B,保证了数据的安全性。 java
Linux 下的传统 IPC 通讯原理: android
(2)稳定性缓存
(3)安全性安全
Binder IPC正是基于内存映射(mmap)来实现的 bash
(1)生成AIDL接口(new->AIDL->AIDL File)架构
interface MyWindowManager {
void sysout();
}
复制代码
生成AIDL文件以后,比起之前多了一个叫作 aidl 的包,并且他的层级是和 java 包相同的。
(2)编译MyWindowManager.aidl生成Java文件ide
public interface MyWindowManager extends android.os.IInterface {
/** Local-side IPC implementation stub class. */
//Stub 继承 Binder, 说明它是一个 Binder 本地对象;实现 IInterface 接口,代表Server能够提供的方法
public static abstract class Stub extends android.os.Binder
implements com.example.myview.binder.MyWindowManager {
private static final java.lang.String DESCRIPTOR = "com.example.myview.binder.MyWindowManager";
/** Construct the stub at attach it to the interface. */
public Stub() {
this.attachInterface(this, DESCRIPTOR);
}
public static com.example.myview.binder.MyWindowManager asInterface(android.os.IBinder obj) {
if ((obj == null)) {
return null;
}
android.os.IInterface iin = obj.queryLocalInterface(DESCRIPTOR);
if (((iin != null) && (iin instanceof com.example.myview.binder.MyWindowManager))) {
return ((com.example.myview.binder.MyWindowManager) iin);
}
return new com.example.myview.binder.MyWindowManager.Stub.Proxy(obj);
}
@Override
public android.os.IBinder asBinder() {
return this;
}
@Override
public boolean onTransact(int code, android.os.Parcel data, android.os.Parcel reply, int flags)
throws android.os.RemoteException {
......
return super.onTransact(code, data, reply, flags);
}
//Binder本地代理对象
private static class Proxy implements com.example.myview.binder.MyWindowManager {
private android.os.IBinder mRemote;
Proxy(android.os.IBinder remote) {
mRemote = remote;
}
@Override
public android.os.IBinder asBinder() {
return mRemote;
}
public java.lang.String getInterfaceDescriptor() {
return DESCRIPTOR;
}
@Override
public void sysout() throws android.os.RemoteException {
android.os.Parcel _data = android.os.Parcel.obtain();
android.os.Parcel _reply = android.os.Parcel.obtain();
try {
_data.writeInterfaceToken(DESCRIPTOR);
mRemote.transact(Stub.TRANSACTION_sysout, _data, _reply, 0);
_reply.readException();
} finally {
_reply.recycle();
_data.recycle();
}
}
}
static final int TRANSACTION_basicTypes = (android.os.IBinder.FIRST_CALL_TRANSACTION + 0);
static final int TRANSACTION_sysout = (android.os.IBinder.FIRST_CALL_TRANSACTION + 1);
}
public void sysout() throws android.os.RemoteException;
}
复制代码
(3)Server端提供方法的具体实现工具
public class MyWindowManagerService extends Service {
@Nullable
@Override
public IBinder onBind(Intent intent) {
return mWindowManager;
}
private final MyWindowManager.Stub mWindowManager = new MyWindowManager.Stub() {
@Override
public void basicTypes(int anInt, long aLong, boolean aBoolean, float aFloat, double aDouble,
String aString) throws RemoteException {
}
@Override
public void sysout() throws RemoteException {
Log.e("hj", "sysout: " );
}
};
}
复制代码
(4)其余进程的Activity实现跟Service的通讯性能
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Intent intent = new Intent(this, MyWindowManagerService.class);
bindService(intent, mConnection, Context.BIND_AUTO_CREATE);
}
ServiceConnection mConnection = new ServiceConnection() {
@Override
public void onServiceConnected(ComponentName name, IBinder service) {
MyWindowManager windowManager = MyWindowManager.Stub.asInterface(service);
try {
windowManager.sysout();
} catch (RemoteException e) {
e.printStackTrace();
}
}
@Override
public void onServiceDisconnected(ComponentName name) {
}
};
}
复制代码
参考文章:
Android Binder设计与实现 - 设计篇
为何 Android 要采用 Binder 做为 IPC 机制?
写给 Android 应用工程师的 Binder 原理剖析ui