在博客园看到的,看着挺不错的,借来分享下

继承Binder类

这个方式仅仅有当你的Acitivity和Service处于同一个Application和进程时,才干够用,比方你后台有一个播放背景音乐的Service,这时就能够用这样的方式来进行通信。

用样例来说明其用法:

1. 来看Service的写法:

public class LocalService extends Service {
// 实例化自己定义的Binder类
private final IBinder mBinder = new LocalBinder();
// 随机数的生成器
private final Random mGenerator = new Random(); /**
* 自己定义的Binder类,这个是一个内部类,所以能够知道其外围类的对象,通过这个类,让Activity知道其Service的对象
*/
public class LocalBinder extends Binder {
LocalService getService() {
// 返回Activity所关联的Service对象,这样在Activity里,就可调用Service里的一些公用方法和公用属性
return LocalService.this;
}
} @Override
public IBinder onBind(Intent intent) {
return mBinder;
} /** public方法,Activity能够进行调用 */
public int getRandomNumber() {
return mGenerator.nextInt(100);
}
}

在Service里定义一个内部类,Binder的子类,通过这个类,把Service的对象传给Activity,这样Activity就能够调用Service里的公用方法和公用属性了,但这样的方式,一定要在同一个进程和同一个Application里。

   2. 再看对应Activity的代码:

public class BindingActivity extends Activity {
LocalService mService;
boolean mBound = false; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
} @Override
protected void onStart() {
super.onStart();
// 绑定Service,绑定后就会调用mConnetion里的onServiceConnected方法
Intent intent = new Intent(this, LocalService.class);
bindService(intent, mConnection, Context.BIND_AUTO_CREATE);
} @Override
protected void onStop() {
super.onStop();
// 解绑Service,这样能够节约内存
if (mBound) {
unbindService(mConnection);
mBound = false;
}
} /** 用户点击button,就读取Service里的随机数 */
public void onButtonClick(View v) {
if (mBound) {
// 用Service的对象,去读取随机数
int num = mService.getRandomNumber();
Toast.makeText(this, "number: " + num, Toast.LENGTH_SHORT).show();
}
} /** 定交ServiceConnection,用于绑定Service的*/
private ServiceConnection mConnection = new ServiceConnection() { @Override
public void onServiceConnected(ComponentName className,
IBinder service) {
// 已经绑定了LocalService,强转IBinder对象,调用方法得到LocalService对象
LocalBinder binder = (LocalBinder) service;
mService = binder.getService();
mBound = true;
} @Override
public void onServiceDisconnected(ComponentName arg0) {
mBound = false;
}
};
}

这里就是通过IBinder来得到LocalService对象,再去调用其Public方法。

使用Messenger

上面的方法仅仅能在同一个进程里才干用,假设要与另外一个进程的Service进行通信,则能够用Messenger。

事实上实现IPC的方式,还有AIDL,但推荐使用Messenger,有两点优点:

1. 使用Messenger方式比使用AIDL的方式,实现起来要简单非常多

2. 使用Messenger时,全部从Activity传过来的消息都会排在一个队列里,不会同一时候请求Service,所以是线程安全的。假设你的程序就是要多线程去訪问Service,就能够用AIDL,不然最好使用Messenger的方式。

只是,事实上Messenger底层用的就是AIDL实现的,看一下实现方式,先看Service的代码:

public class MessengerService extends Service {
/** 用于Handler里的消息类型 */
static final int MSG_SAY_HELLO = 1; /**
* 在Service处理Activity传过来消息的Handler
*/
class IncomingHandler extends Handler {
@Override
public void handleMessage(Message msg) {
switch (msg.what) {
case MSG_SAY_HELLO:
Toast.makeText(getApplicationContext(), "hello!", Toast.LENGTH_SHORT).show();
break;
default:
super.handleMessage(msg);
}
}
} /**
* 这个Messenger能够关联到Service里的Handler,Activity用这个对象发送Message给Service,Service通过Handler进行处理。
*/
final Messenger mMessenger = new Messenger(new IncomingHandler()); /**
* 当Activity绑定Service的时候,通过这种方法返回一个IBinder,Activity用这个IBinder创建出的Messenger,就能够与Service的Handler进行通信了
*/
@Override
public IBinder onBind(Intent intent) {
Toast.makeText(getApplicationContext(), "binding", Toast.LENGTH_SHORT).show();
return mMessenger.getBinder();
}
}

Activity代码实现

public class ActivityMessenger extends Activity {
/** 向Service发送Message的Messenger对象 */
Messenger mService = null; /** 推断有没有绑定Service */
boolean mBound; private ServiceConnection mConnection = new ServiceConnection() {
public void onServiceConnected(ComponentName className, IBinder service) {
// Activity已经绑定了Service
// 通过參数service来创建Messenger对象,这个对象能够向Service发送Message,与Service进行通信
mService = new Messenger(service);
mBound = true;
} public void onServiceDisconnected(ComponentName className) {
mService = null;
mBound = false;
}
}; public void sayHello(View v) {
if (!mBound) return;
// 向Service发送一个Message
Message msg = Message.obtain(null, MessengerService.MSG_SAY_HELLO, 0, 0);
try {
mService.send(msg);
} catch (RemoteException e) {
e.printStackTrace();
}
} @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
} @Override
protected void onStart() {
super.onStart();
// 绑定Service
bindService(new Intent(this, MessengerService.class), mConnection,
Context.BIND_AUTO_CREATE);
} @Override
protected void onStop() {
super.onStop();
// 解绑
if (mBound) {
unbindService(mConnection);
mBound = false;
}
}
}

注意:以上写的代码仅仅能实现从Activity向Service发送消息,假设想从Service向Activity发送消息,仅仅要把代码反过来写就能够了。

使用AIDL

这种方法略,假设知道上面两种方法,这种方法基本非常少会用到。

Activity与Service通信的方式有三种:的更多相关文章

  1. Activity与Service通信

    Activity与Service通信的方式有三种: 继承Binder类 这个方式只有当你的Acitivity和Service处于同一个Application和进程时,才可以用,比如你后台有一个播放背景 ...

  2. Activity与Service通信(不同进程之间)

    使用Messenger 上面的方法只能在同一个进程里才能用,如果要与另外一个进程的Service进行通信,则可以用Messenger. 其实实现IPC(Inter-Process Communicat ...

  3. android学习-IPC机制之ACtivity绑定Service通信

    bindService获得Service的binder对象对服务进行操作 Binder通信过程类似于TCP/IP服务连接过程binder四大架构Server(服务器),Client(客户端),Serv ...

  4. Android之Activity与Service通信

    一.当Acitivity和Service处于同一个Application和进程时,通过继承Binder类来实现. 当一个Activity绑定到一个Service上时,它负责维护Service实例的引用 ...

  5. 201709012工作日记--activity与service的通信机制

    service生命周期 Service主要包含本地类和远程类. Service不是Thread,Service 是android的一种机制,当它运行的时候如果是Local Service,那么对应的 ...

  6. activity 与 service 之间的通信

    activity和service通信:通过binder 举个我实际项目中的例子:在service中下载更新应用 首先是下载更新apk的service: public class UpdateVersi ...

  7. Android四大组件应用系列——Activity与Service交互实现APK下载

    Servic与Activity相比它没有界面,主要是在后台执行一些任务,Service有两种启动方法startService()和bindService(),startService方式Service ...

  8. Android中Activity、Service和线程之间的通信

    Activity.Service和线程应该是Android编程中最常见的几种类了,几乎大多数应用程序都会涉及到这几个类的编程,自然而然的,也就会涉及到三者之间的相互通信,本文就试图简单地介绍一下这三者 ...

  9. Android学习总结(四)—— Activity和 Service进行通信

    一.Activity 和 Service进行通信的基本概念 前面我们学习我生命周期里面包含了启动和停止服务的方法,虽然服务器在活动里启动,但在启动了服务之后,活动与服务基本就没有什么关系了.我们在活动 ...

随机推荐

  1. Ultra Office Control 2.0

    http://www.ultrashareware.com/Ultra-Office-Control.htm

  2. WCF技术剖析之十八:消息契约(Message Contract)和基于消息契约的序列化

    原文:WCF技术剖析之十八:消息契约(Message Contract)和基于消息契约的序列化 [爱心链接:拯救一个25岁身患急性白血病的女孩[内有苏州电视台经济频道<天天山海经>为此录制 ...

  3. python编写网络抓包分析脚本

    python编写网络抓包分析脚本 写网络抓包分析脚本,一个称手的sniffer工具是必不可少的,我习惯用Ethereal,简单,易用,基于winpcap的一个开源的软件 Ethereal自带许多协议的 ...

  4. skip32

    在某些应用场景下,需要对数字进行加密,skip32无疑是一种很实用的算法,网上有python的源码(https://bitbucket.org/anuraguniyal/skip32.py/src/4 ...

  5. asp.net2.0安全性(1)--用户角色篇(起篇)--转载来自车老师

    安全管理的解决方案在.net1.1中几乎为一片空白,对于应用程序的验证与授权大部分的工作是开发人员自己编写代码,或者是借助企业库等工具来实现,此可谓.net1.1中的一大缺憾.在.net2.0中微软为 ...

  6. Spring3表达式语言(SpEL)学习笔记

    最新地址请访问:http://leeyee.github.io/blog/2011/06/19/spring-expression-language Spring Excpression Langua ...

  7. CCNP交换实验(7) -- NAT

    1.静态NAT2.动态NAT3.复用内部全局地址的NAT(PAT) enableconf tno ip do loenable pass ciscoline con 0logg syncexec-t ...

  8. JavaScript编程:java事件模型

    3.java事件模型: 传统事件处理程序指派方法:          1.var odiv=document.getElementById("div1");             ...

  9. UML之九图概述

    最近看了UML的九种图的讲解,这九种图在我们以后的学习中起着举足轻重的作用,不管是在写文档,还是在对系统的需求.设计进行分析时,都很重要,所以首先做一下概述,希望能和大家分享. 首先和大家展示一下我对 ...

  10. .net生成Excel,并下载

    生成Excel的方式有很多种,这里记录两个最简单的: 1.将数据保存为html,然后输出到客户端,保存为Excel文件: 2.通过\t\n生成字符串,然后输出到客户端,保存为Excel. 以上两者的原 ...