Android开发使用Messenger及Handler进行通信的方法示例

本文实例讲述了Android开发使用Messenger及Handler进行通信的方法。分享给大家供大家参考,具体如下:

1. 客户端service

public class MessageService extends Service {
 private static final int MSG_SET_VALUE = 0x110;
 private Handler mHandler = new Handler() {
  public void handleMessage(Message msgFromClient) {
   // 返回给客户的信息
   Message msgToClient = Message.obtain(msgFromClient);
   switch (msgFromClient.what) {
   // msg 客户端传来的消息
   case MSG_SET_VALUE:
    try {
     msgToClient.what = MSG_SET_VALUE;
     SystemClock.sleep(2000);
     msgToClient.arg2 = msgFromClient.arg1 + msgFromClient.arg2;
     //msgFromClient.replyTo.send(msgToClient);
     //得到客户端的信使对象,并向它发送消息
     cMessenger = msgFromClient.replyTo;
     cMessenger.send(msgToClient);
    } catch (RemoteException e) {
     e.printStackTrace();
    }
    break;
   default:
    break;
   }
  }
 };
 private Messenger mMessager = new Messenger(mHandler);
 private Messenger cMessenger;
 @Override
 public IBinder onBind(Intent intent) {
  return mMessager.getBinder();
 }
 @Override
 public void onDestroy() {
  cMessenger = null;
  super.onDestroy();
 }
}

2. 服务器端service

public class MessageService extends Service {
 private static final int MSG_SET_VALUE = 0x110;
 private Handler mHandler = new Handler() {
  public void handleMessage(Message msgFromClient) {
   // 返回给客户的信息
   Message msgToClient = Message.obtain(msgFromClient);
   switch (msgFromClient.what) {
   // msg 客户端传来的消息
   case MSG_SET_VALUE:
    try {
     msgToClient.what = MSG_SET_VALUE;
     SystemClock.sleep(2000);
     msgToClient.arg2 = msgFromClient.arg1 + msgFromClient.arg2;
     //msgFromClient.replyTo.send(msgToClient);
     //得到客户端的信使对象,并向它发送消息
     cMessenger = msgFromClient.replyTo;
     cMessenger.send(msgToClient);
    } catch (RemoteException e) {
     e.printStackTrace();
    }
    break;
   default:
    break;
   }
  }
 };
 private Messenger mMessager = new Messenger(mHandler);
 private Messenger cMessenger;
 @Override
 public IBinder onBind(Intent intent) {
  return mMessager.getBinder();
 }
 @Override
 public void onDestroy() {
  cMessenger = null;
  super.onDestroy();
 }
}

3. 客户端使用

public class MainActivity extends Activity {
 private static final int MSG_SET_VALUE = 0x110;
 private TextView mTVStatus; // 连接状态
 private LinearLayout mLLContainer;// 用来添加接收到服务器返回的信息
 private Messenger mService; // 客户端信使
 private boolean isConnecting; // 是否连接
 private Handler mHandler = new Handler() {
  public void handleMessage(Message msgFromServer) {
   switch (msgFromServer.what) {
   case MSG_SET_VALUE:
    TextView tv = (TextView) findViewById(msgFromServer.arg1);
    tv.setText(tv.getText() + "==>" + msgFromServer.arg2);
    break;
   }
   super.handleMessage(msgFromServer);
  };
 };
 private Messenger mMessenger = new Messenger(mHandler);
 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
  mTVStatus = (TextView) findViewById(R.id.tv_status);
  mLLContainer = (LinearLayout) findViewById(R.id.ll_container);
 }
 int i = 0;
 public void send(View view){
  try {
   int a = i++;
   int b = (int) (Math.random() * 100);
   //创建一个tv,添加到LinearLayout中
   TextView tv = new TextView(MainActivity.this);
   tv.setText(a + " + " + b + " = caculating ...");
   tv.setId(a);
   mLLContainer.addView(tv);
   Message msgFromClient = Message.obtain(null, MSG_SET_VALUE, a, b);
   msgFromClient.replyTo = mMessenger;
   if (isConnecting) {
    //往服务端发送消息
    mService.send(msgFromClient);
   }
  } catch (RemoteException e) {
   e.printStackTrace();
  }
 }
 public void bind(View view) {
  Intent service = new Intent();
  service.setAction("android.intent.action.MESSAGE_SERVER");
  bindService(service, conn, Context.BIND_AUTO_CREATE);
 }
 private ServiceConnection conn = new ServiceConnection() {
  @Override
  public void onServiceDisconnected(ComponentName name) {
   mService = null;
   isConnecting = false;
   mTVStatus.setText("已断开连接!");
  }
  @Override
  public void onServiceConnected(ComponentName name, IBinder service) {
   mService = new Messenger(service);
   isConnecting = true;
   mTVStatus.setText("连接成功!");
  }
 };
 public void unbind(View view) {
  unbindService(conn);
  conn = null;
 }
 @Override
 protected void onDestroy() {
  unbindService(conn);
  conn = null;
  super.onDestroy();
 }
}

更多关于Android相关内容感兴趣的读者可查看本站专题:《Android通信方式总结》、《Android开发入门与进阶教程》、《Android调试技巧与常见问题解决方法汇总》、《Android基本组件用法总结》、《Android视图View技巧总结》、《Android布局layout技巧总结》及《Android控件用法总结》

希望本文所述对大家Android程序设计有所帮助。

(0)

相关推荐

  • Android编程之客户端通过socket与服务器通信的方法

    本文实例讲述了Android编程之客户端通过socket与服务器通信的方法.分享给大家供大家参考,具体如下: 下面是一个demo,Android客户端通过socket与服务器通信. 由于Android里面可以完全使用java.io.*包和java.net.*包,那么,实际上,逻辑部分与J2SE没有区别.只是UI代码不一样. Android客户端通过socket与服务器通信分为下面5步: (1)通过IP地址和端口实例化Socket,请求连接服务器: 复制代码 代码如下: socket = new

  • Android之网络通信案例分析

    由于一个项目的需要,我研究了一下android的网络通信方式,大体和java平台的很相似!  android平台也提供了很多的API供开发者使用,请按示例图:  首先,介绍一下通过http包工具进行通信,分get和post两种方式,两者的区别是: 1,post请求发送数据到服务器端,而且数据放在html header中一起发送到服务器url,数据对用户不可见,get请求是把参数值加到url的队列中,这在一定程度上,体现出post的安全性要比get高 2,get传送的数据量小,一般不能大于2kb,

  • Android网络编程之UDP通信模型实例

    什么是Android UDP? UDP是User Datagram Protocol的简称,中文名是用户数据包协议,是OSI参考模型中一种无连接的传输层协议,提供面向事务的简单不可靠信息传送服务.它是IETF RFC 768是UDP的正式规范.在网络中它与TCP协议一样用于处理数据包.在OSI模型中,在第四层-传输层,处于IP协议的上一层.UDP有不提供数据报分组.组装和不能对数据包的排序的缺点,也就是说,当报文发送之后,是无法得知其是否安全完整到达的.UDP用来支持那些需要在计算机之间传输数据

  • Android Socket通信详解

    一.Socket通信简介  Android与服务器的通信方式主要有两种,一是Http通信,一是Socket通信.两者的最大差异在于,http连接使用的是"请求-响应方式",即在请求时建立连接通道,当客户端向服务器发送请求后,服务器端才能向客户端返回数据.而Socket通信则是在双方建立起连接后就可以直接进行数据的传输,在连接时可实现信息的主动推送,而不需要每次由客户端想服务器发送请求. 那么,什么是socket?Socket又称套接字,在程序内部提供了与外界通信的端口,即端口通信.通过

  • Android Handler主线程和一般线程通信的应用分析

    Handler的定义:主要接受子线程发送的数据, 并用此数据配合主线程更新UI.解释: 当应用程序启动时,Android首先会开启一个主线程 (也就是UI线程) , 主线程为管理界面中的UI控件,进行事件分发, 比如说, 你要是点击一个 Button ,Android会分发事件到Button上,来响应你的操作.如果此时需要一个耗时的操作,例如: 联网读取数据,或者读取本地较大的一个文件的时候,你不能把这些操作放在主线程中,如果你放在主线程中的话,界面会出现假死现象, 如果5秒钟还没有完成的话,会

  • Android单片机与蓝牙模块通信实例代码

    啦啦毕业了,毕业前要写毕业设计,需要写一个简单的蓝牙APP进行交互,通过参考网上资料,问题顺利搞定,下面小编把具体实现思路分享给大家,供大家参考. 1.Android蓝牙编程 蓝牙3.0及以下版本编程需要使用UUID,UUID是通用唯一识别码(Universally Unique Identifier),这是一个软件构建的标准,也是被开源基金会组织应用在分布式计算环境领域的一部分.在蓝牙3.0及下一版本中,UUID被用于唯一标识一个服务,比如文件传输服务,串口服务.打印机服务等,如下: #蓝牙串

  • 深入理解Android中的Handler异步通信机制

    一.问题:在Android启动后会在新进程里创建一个主线程,也叫UI线程(非线程安全)这个线程主要负责监听屏幕点击事件与界面绘制.当Application需要进行耗时操作如网络请求等,如直接在主线程进行容易发生ANR错误.所以会创建子线程来执行耗时任务,当子线程执行完毕需要通知UI线程并修改界面时,不可以直接在子线程修改UI,怎么办? 解决方法:Message Queue机制可以实现子线程与UI线程的通信. 该机制包括Handler.Message Queue.Looper.Handler可以把

  • 深入Android Handler与线程间通信ITC的详解

    在<Android Handler之消息循环的深入解析>中谈到了Handler是用于操作线程内部的消息队列,所以Handler可以用来线程间通信ITC,这种方式更加安全和高效,可以大大减少同步的烦恼,甚至都可以不用syncrhonized.线程间通讯ITC正常情况下函数调用栈都会生存在同一个线程内,想要把执行逻辑交换到其他线程可以新建一个Thread,然后start().另外一种方法就是用ITC,也即用消息队列来实现,线程需要把执行逻辑交到其他线程时就向另外的线程的消息队列发送一个消息,发送消

  • Android进程通信之Messenger和AIDL使用详解

    1. 前言 提到的进程间通信(IPC:Inter-Process Communication),在Android系统中,一个进程是不能直接访问另一个进程的内存的,需要提供一些机制在不同的进程之间进行通信,Android官方推出了AIDL(Android Interface Definition Language),它是基于Binder机制的. 上篇提到组件在与Service通信方法有三种. 实现IBinder Messenger AIDL 后面两种可以跨进程通信,是基于Binder机制的通信方式

  • Android 进程间通信实现原理分析

    Android Service是分为两种: 本地服务(Local Service): 同一个apk内被调用 远程服务(Remote Service):被另一个apk调用远程服务需要借助AIDL来完成. AIDL 是什么 AIDL (Android Interface Definition Language) 是一种IDL 语言,用于生成可以在Android设备上两个进程之间进行进程间通信(interprocess communication, IPC)的代码.如果在一个进程中(例如Activit

  • Android IPC机制利用Messenger实现跨进程通信

    写作原因:跨进程通信的实现和理解是Android进阶中重要的一环.下面博主分享IPC一些相关知识.操作及自己在学习IPC过程中的一些理解.这一章使用Messenger实现跨进程通信,其中bindService基础部分参见Android IPC机制绑定Service实现本地通信. 跨进程简介 在介绍使用Messenger跨进程通信之前先要了解以下问题:为什么需要跨进程通信?只有有了需求才有学习的价值.我个人将不同进程简单的理解为不同的应用程序(当然也有例外,比如可以在同一个应用程序中开启两个或多个

随机推荐