ipc,跨进程通信,android通过binder机制进行进程中的通信,
在android中一个进程一般指一个应用,也可以通过在androidmanifes中指定process属性来实现多进程
多进程实现很简单,但是多进程间的数据传递不简单
当启动一个不同进程的activity时,application会重新执行oncreate方法,同时,不同的进程,相同的类会分配到不同的地址空间
比如在一个静态类中定义了一个数据,在1进程中修改后,在2进程中调用,数据还是最原始的数据,虽然1,2进程同属于一个应用也,也无法通过静态类的方式得到修改后的值
android序列化的俩种方式,
1,serializable接口
通过继承serializable接口实现数据的序列化,需要定义serailversionuid,这个id用来反序列化的时候使用
如果不需要反序列化,可以不定义这个id
序列化和反序列化代码举例
//序列化过程
User user =new User(0,”jake”,true);
ObjectOutPutStream out=new ObjectOutputstream(new fileOutputstram(“cache.txt));
out.writeObject(user);
out.close();
//反序列化过程
ObjectintPutStream in=new Objectintputstream(new fileintputstram(“cache.txt));
User user=(User)in.readObject();
in.close();
parcelable接口
在android studio中继承parcelable接口后,根据提示会自动生成序列化的代码,且在android中推荐使用parcelable接口实现序列化效率更高
android ipc通信 跨进程通信方式
1,bundle
bundle支持跨进程通信,但是传输的数据都是需要实例化的
2,文件共享
通过不同进程操作同一个文件,进行读写实现跨进程通信的目的
3,message
message通常在server中使用,创建一个server类继承server
通过onbind方法向客户端返回ibinder实例,用来与服务器进行通信
客户端实现serviceConnection 通过message.send方法向服务器发送数据
服务端可以通过handlemessage处理客户端发送过来的数据
4,contentprovide
provide需要在manifest中注册,authorities为唯一标识符
外部进程通过Uri uri=Uri.parse(“content://authorties”)获取uri实例
在通过getContentResolver().query(uri,null,null,null,null);进行查询,
5.socket
通过指定端口,通过输入输出流进行通信