Android应用进程间通信之Messenger信使使用及源码浅析(1)

<application

android:allowBackup=“true”

android:icon=“@mipmap/ic_launcher”

android:label=“@string/app_name”

android:theme=“@style/AppTheme” >

<activity

android:name=“.MainActivity”

android:label=“@string/app_name” >

<service android:name=“.RemoteService”

android:process=“:remote”>

工程中的一个独立进程服务端remote源码:

/**

  • 另一个进程中的Service

*/

public class RemoteService extends Service {

public static final int MSG_TAG_REMOTE = 0x110;

public static final int MSG_TAG_CLIENT = 0x111;

private Messenger mRemoteMessenger;

private RemoteHandler mRemoteHandler;

private int mCounter = 0;

@Override

public void onCreate() {

super.onCreate();

mRemoteHandler = new RemoteHandler();

//实例化一个Messenger传入当前Handler

mRemoteMessenger = new Messenger(mRemoteHandler);

}

@Override

public IBinder onBind(Intent intent) {

return (mRemoteMessenger == null) ? null : mRemoteMessenger.getBinder();

}

private class RemoteHandler extends Handler {

@Override

public void handleMessage(Message msg) {

switch (msg.what) {

case MSG_TAG_REMOTE:

//为了把消息回传给client端,所以获取client端设置的Messenger

Messenger clientMessenger = msg.replyTo;

if (clientMessenger != null) {

try {

//注意obtain第一个参数,前面文章有解释,因为参数target不可序列化

clientMessenger.send(Message.obtain(null, MSG_TAG_CLIENT, ++mCounter, 0));

} catch (RemoteException e) {

e.printStackTrace();

}

}

break;

default:

super.handleMessage(msg);

break;

}

}

}

}

工程中的一个独立进程客户端client代码:

public class MainActivity extends Activity {

private TextView mTextView;

private Messenger mRemoteMessenger = null;

private Messenger mClientMessenger;

private ClientHandler mClientHandler;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

mTextView = (TextView) findViewById(R.id.content_show);

//

mClientHandler = new ClientHandler();

mClientMessenger = new Messenger(mClientHandler);

bindService(new Intent(this, RemoteService.class), connection, Context.BIND_AUTO_CREATE);

}

@Override

protected void onDestroy() {

super.onDestroy();

unbindService(connection);

}

private ServiceConnection connection = new ServiceConnection() {

@Override

public void onServiceConnected(ComponentName name, IBinder service) {

mRemoteMessenger = new Messenger(service);

//注意obtain第一个参数,前面文章有解释

Message message = Message.obtain(null, RemoteService.MSG_TAG_REMOTE);

message.replyTo = mClientMessenger;

try {

mRemoteMessenger.send(message);

} catch (RemoteException e) {

e.printStackTrace();

}

}

@Override

public void onServiceDisconnected(ComponentName name) {}

};

private class ClientHandler extends Handler {

@Override

public void handleMessage(Message msg) {

switch (msg.what) {

case RemoteService.MSG_TAG_CLIENT:

if (mTextView != null) {

mTextView.setText(msg.arg1+“”);

}

break;

default:

super.handleMessage(msg);

break;

}

}

}

}

看着了吧,这就是一个超级简单的Messenger使用场景,具体过程比较形象的描述如下图:

这里写图片描述

相信有了这幅图就不需要再解释啥了吧,这个也够明白了。

【工匠若水 http://blog.csdn.net/yanbober 转载请注明出处。点我开始Android技术交流

3 Messenger源码浅析


通过上面的实例明显可以看出,在不考虑并发的情况下,Messenger相比AIDL无论从代码量、工程结构、复杂度等上都更加胜出一筹。既然这么好用的东东,那就来看看他的源码吧,如下我们先通观一下Messenger类的整个核心代码,然后再细说。如下所示:

/**

  • 关联Handler进行跨进程收发消息的信使管理桥梁类

  • 可以看见Messenger就是一个信使,就是一个Object

*/

public final class Messenger implements Parcelable {

//其实就是远程的MessengerService的AIDL接口

private final IMessenger mTarget;

//创建一个指向target Handler的Messenger,然后调运Messenger的send就像Handler的sendMessage

public Messenger(Handler target) {

mTarget = target.getIMessenger();

}

//跨进程发送消息,通常用Message.obtain()填充message参数,也可以自己new

public void send(Message message) throws RemoteException {

mTarget.send(message);

}

//获得Messenger的Binder,一般用在remote端获取返回

public IBinder getBinder() {

return mTarget.asBinder();

}

//如果两个Messenger相等则表明指向了相同的Handler

public boolean equals(Object otherObj) {

if (otherObj == null) {

return false;

}

try {

return mTarget.asBinder().equals(((Messenger)otherObj)

.mTarget.asBinder());

} catch (ClassCastException e) {

文末

对于很多初中级Android工程师而言,想要提升技能,往往是自己摸索成长,不成体系的学习效果低效漫长且无助。 整理的这些架构技术希望对Android开发的朋友们有所参考以及少走弯路,本文的重点是你有没有收获与成长,其余的都不重要,希望读者们能谨记这一点。

最后想要拿高薪实现技术提升薪水得到质的飞跃。最快捷的方式,就是有人可以带着你一起分析,这样学习起来最为高效,所以为了大家能够顺利进阶中高级、架构师,我特地为大家准备了一套高手学习的源码和框架视频等精品Android架构师教程,保证你学了以后保证薪资上升一个台阶。

当你有了学习线路,学习哪些内容,也知道以后的路怎么走了,理论看多了总要实践的。

进阶学习视频

附上:我们之前因为秋招收集的二十套一二线互联网公司Android面试真题 (含BAT、小米、华为、美团、滴滴)和我自己整理Android复习笔记(包含Android基础知识点、Android扩展知识点、Android源码解析、设计模式汇总、Gradle知识点、常见算法题汇总。)

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

Android面试真题** (含BAT、小米、华为、美团、滴滴)和我自己整理Android复习笔记(包含Android基础知识点、Android扩展知识点、Android源码解析、设计模式汇总、Gradle知识点、常见算法题汇总。)

[外链图片转存中…(img-gRSwldQM-1714408657626)]

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 25
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值