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

使用Messenger

上面的方法只能在同一个进程里才能用,如果要与另外一个进程的Service进行通信,则可以用Messenger。

其实实现IPC(Inter-Process Communication,进程间通信)的方式,还有AIDL,但推荐使用Messenger,有两点好处:

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

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

不过,其实Messenger底层用的就是AIDL实现的,看一下实现方式,先看Service的代码:

1.public class MessengerService extends Service {
2.    /** 用于Handler里的消息类型 */
3.    static final int MSG_SAY_HELLO = 1;
4.
5.    /**
6.     * 在Service处理Activity传过来消息的Handler
7.     */
8.    class IncomingHandler extends Handler {
9.        @Override
10.        public void handleMessage(Message msg) {
11.            switch (msg.what) {
12.                case MSG_SAY_HELLO:
13.                    Toast.makeText(getApplicationContext(), "hello!", Toast.LENGTH_SHORT).show();
14.                    break;
15.                default:
16.                    super.handleMessage(msg);
17.            }
18.        }
19.    }
20.
21.    /**
22.     * 这个Messenger可以关联到Service里的Handler,Activity用这个对象发送Message给Service,Service通过Handler进行处理。
23.     */
24.    final Messenger mMessenger = new Messenger(new IncomingHandler());
25.
26.    /**
27.     * 当Activity绑定Service的时候,通过这个方法返回一个IBinder,Activity用这个IBinder创建出的Messenger,就可以与Service的Handler进行通信了
28.     */
29.    @Override
30.    public IBinder onBind(Intent intent) {
31.        Toast.makeText(getApplicationContext(), "binding", Toast.LENGTH_SHORT).show();
32.        return mMessenger.getBinder();
33.    }
34.}  

再看一下Activity的代码:

1.public class ActivityMessenger extends Activity {
2.    /** 向Service发送Message的Messenger对象 */
3.    Messenger mService = null;
4.
5.    /** 判断有没有绑定Service */
6.    boolean mBound;
7.
8.    private ServiceConnection mConnection = new ServiceConnection() {
9.        public void onServiceConnected(ComponentName className, IBinder service) {
10.            // Activity已经绑定了Service
11.            // 通过参数service来创建Messenger对象,这个对象可以向Service发送Message,与Service进行通信
12.            mService = new Messenger(service);
13.            mBound = true;
14.        }
15.
16.        public void onServiceDisconnected(ComponentName className) {
17.            mService = null;
18.            mBound = false;
19.        }
20.    };
21.
22.    public void sayHello(View v) {
23.        if (!mBound) return;
24.        // 向Service发送一个Message
25.        Message msg = Message.obtain(null, MessengerService.MSG_SAY_HELLO, 0, 0);
26.        try {
27.            mService.send(msg);
28.        } catch (RemoteException e) {
29.            e.printStackTrace();
30.        }
31.    }
32.
33.    @Override
34.    protected void onCreate(Bundle savedInstanceState) {
35.        super.onCreate(savedInstanceState);
36.        setContentView(R.layout.main);
37.    }
38.
39.    @Override
40.    protected void onStart() {
41.        super.onStart();
42.        // 绑定Service
43.        bindService(new Intent(this, MessengerService.class), mConnection,
44.            Context.BIND_AUTO_CREATE);
45.    }
46.
47.    @Override
48.    protected void onStop() {
49.        super.onStop();
50.        // 解绑
51.        if (mBound) {
52.            unbindService(mConnection);
53.            mBound = false;
54.        }
55.    }
56.}  

注意:以上写的代码只能实现从Activity向Service发送消息,如果想从Service向Activity发送消息,只要把代码反过来写就可以了。

使用AIDL

  AIDL,Android Interface Definition Language。建立AIDL服务要比建立普通的服务复杂一些,具体步骤如下:

  (1)在Eclipse Android工程的Java包目录中建立一个扩展名为aidl的文件。该文件的语法类似于Java代码,但会稍有不同。详细介绍见实例的内容。

  (2)如果aidl文件的内容是正确的,ADT会自动生成一个Java接口文件(*.java)。

  (3)建立一个服务类(Service的子类)。

  (4)实现由aidl文件生成的Java接口。

  (5)在AndroidManifest.xml文件中配置AIDL服务,尤其要注意的是,<action>标签中android:name的属性值就是客户端要引用该服务的ID,也就是Intent类的参数值。

时间: 2024-07-29 18:57:49

Activity与Service通信(不同进程之间)的相关文章

Android之Activity与Service通信

一.当Acitivity和Service处于同一个Application和进程时,通过继承Binder类来实现. 当一个Activity绑定到一个Service上时,它负责维护Service实例的引用,允许你对正在运行的Service进行一些方法调用.比如你后台有一个播放背景音乐的Service,这时就可以用这种方式来进行通信. 代码如下: /*************************Service代码****************************************/ p

activity 和service通信,调用service方法

package com.evt.services; import java.io.FileDescriptor; import java.io.PrintWriter; import com.evt.MyApplication; import android.app.Service; import android.content.Intent; import android.os.Binder; import android.os.IBinder; import android.util.Log

activity 与 service 之间的通信

activity和service通信:通过binder 举个我实际项目中的例子:在service中下载更新应用 首先是下载更新apk的service: public class UpdateVersionService extends Service { private final String tag = "young"; private Context context = this; private BaseApplication application; private Down

进程之间的通信

1无名管道( pipe ):管道是一种半双工的通信方式,数据只能单向流动,而且只能在具有亲缘关系的进程间使用.进程的亲缘关系通常是指父子进程关系. 2.高级管道(popen):将另一个程序当做一个新的进程在当前程序进程中启动,则它算是当前程序的子进程,这种方式我们成为高级管道方式.3 有名管道 (named pipe) : 有名管道也是半双工的通信方式,但是它允许无亲缘关系进程间的通信.4信号量( semophore ) : 信号量是一个计数器,可以用来控制多个进程对共享资源的访问.它常作为一种

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

Servic与Activity相比它没有界面,主要是在后台执行一些任务,Service有两种启动方法startService()和bindService(),startService方式Service不可交互,可一直在后台即便应用结束,bindService方式可通过ServiceConnection获得运行的Service实例的方式实现Activity和Service之间的交互,通常Activity退出则绑定的服务也就取消了.我们可以通过同时执行启动服务和绑定服务的方式实现Service交互同

使用Messenger进行Activity与Service之间的相互通信

在Android开发中,有时候我们需要让一个Activity绑定一个Service,进行两者之间的通信.当Activity绑定成功以后,就可以调用Service中的public(或有对应可见级别)的方法.如果Service想把一些信息反馈给Activity,则需要将Activity的Listener传递给Service,由Service负责调用. 这样的做法是可以实现功能的,但有一些缺憾. 首先,Service需要把被调用的方法做成public的,不利于隐藏实现. 第二,调用显得凌乱,在Acti

activity与service进程内通信

package com.example.binbin.testbinder; import android.app.Service; import android.content.Intent; import android.os.Binder; import android.os.IBinder; import android.support.annotation.Nullable; import android.util.Log; import android.widget.Toast; /

Android基础笔记(十一)- Service基础和注意事项以及Activity与Service的通信

Service的基本概念 为什么要有Service Service的基本用法 电话窃听器的小案例 Service和Activity通信 Service和Thread的关系 向光明而行! Service的基本概念 Service是Android的四大组件之一,在每一个应用程序中都扮演者非常重要的角色. 它主要用于在后台处理一些耗时的逻辑,或者去执行某些需要长期运行的任务.必要的时候,我们甚至可以在程序退出的情况下,让Service在后台继续保持运行状态. 既然都是被用于处理耗时的操作,那么我们什么

c# IPC实现本机进程之间的通信

IPC可以实现本地进程之间通信.这种用法不是太常见,常见的替代方案是使用wcf,remoting,web service,socket(tcp/pipe/...)等其他分布式部署方案来替代进程之间的通信.虽然不常见但也避免不了一些场景会使用该方案. 应用包含: 1)使用IPC技术实现多client与一个sever通信(不过是本机,感觉意义不大,但如果想实现本机上运行确实是一个不错的方案): 2)使用IPC技术实现订阅者和生产者分离时,一个server接收并消费消息,客户端是生产消息的. 1 1: