当前位置:  编程技术>移动开发

Android多线程处理机制中的Handler使用介绍

    来源: 互联网  发布时间:2014-10-18

    本文导语:  接下来让我介绍Android的Handler的使用方法。Handler可以发送Messsage和Runnable对象到与其相关联的线程的消息队列。每个Handler对象与创建它的线程相关联,并且每个Handler对象只能与一个线程相关联。 Handler一般有两种用途:1)执行...

接下来让我介绍Android的Handler的使用方法。Handler可以发送Messsage和Runnable对象到与其相关联的线程的消息队列。每个Handler对象与创建它的线程相关联,并且每个Handler对象只能与一个线程相关联。

Handler一般有两种用途:1)执行计划任务,你可以再预定的实现执行某些任务,可以模拟定时器。2)线程间通信。在Android的应用启动时,会创建一个主线程,主线程会创建一个消息队列来处理各种消息。当你创建子线程时,你可以再你的子线程中拿到父线程中创建的Handler对象,就可以通过该对象向父线程的消息队列发送消息了

MainActivity.java
[java]
代码如下:

package com.example.thread;
import android.os.Bundle;
import android.os.Handler;
import android.os.Looper;
import android.os.Message;
import android.app.Activity;
import android.view.Menu;
import android.widget.TextView;
public class MainActivity extends Activity {
private TextView tv;
// 消息处理者
private Handler handler;
private static final int TURNTEXT = 1;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// setContentView(R.layout.activity_main);
System.out.println("主线程----" + Thread.currentThread().getName());
tv = new TextView(this);
tv.setText("你好");
setContentView(tv);
// 处理者
handler = new Handler() {
// handlerMessage方法处理handler发送的消息
@Override
public void handleMessage(Message msg) {
super.handleMessage(msg);
// msg.what操作获取发送什么消息,根据消息的标识,进行不同处理方式
int what = msg.what;
if (what == TURNTEXT) {
tv.setText(System.currentTimeMillis() + "");
}
}
};
try {
//主线程 阻塞 6s 大于
Thread.sleep(10000);
} catch (InterruptedException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
//run方法执行完毕 线程就死掉
new Thread(new Runnable() {
@Override
public void run() {
while (true) {
try {
System.out.println("子线程----"
+ Thread.currentThread().getName());
Thread.sleep(1000);
// 发送消息 what标识
handler.sendEmptyMessage(TURNTEXT);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}).start();
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.main, menu);
return true;
}
}
package com.example.thread;
import android.os.Bundle;
import android.os.Handler;
import android.os.Looper;
import android.os.Message;
import android.app.Activity;
import android.view.Menu;
import android.widget.TextView;
public class MainActivity extends Activity {
private TextView tv;
// 消息处理者
private Handler handler;
private static final int TURNTEXT = 1;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// setContentView(R.layout.activity_main);
System.out.println("主线程----" + Thread.currentThread().getName());
tv = new TextView(this);
tv.setText("你好");
setContentView(tv);
// 处理者
handler = new Handler() {
// handlerMessage方法处理handler发送的消息
@Override
public void handleMessage(Message msg) {
super.handleMessage(msg);
// msg.what操作获取发送什么消息,根据消息的标识,进行不同处理方式
int what = msg.what;
if (what == TURNTEXT) {
tv.setText(System.currentTimeMillis() + "");
}
}
};
try {
//主线程 阻塞 6s 大于
Thread.sleep(10000);
} catch (InterruptedException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
//run方法执行完毕 线程就死掉
new Thread(new Runnable() {
@Override
public void run() {
while (true) {
try {
System.out.println("子线程----"
+ Thread.currentThread().getName());
Thread.sleep(1000);
// 发送消息 what标识
handler.sendEmptyMessage(TURNTEXT);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}).start();
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.main, menu);
return true;
}
}

    
 
 

您可能感兴趣的文章:

  • android使用handler ui线程和子线程通讯更新ui示例
  • Android 在其他线程中更新UI线程的解决方法
  • Android开发笔记之:如何安全中止一个自定义线程Thread的方法
  • Handler与Android多线程详解
  • 浅析android中的线程封装
  • Android Handler主线程和一般线程通信的应用分析
  • android开发教程之子线程中更新界面
  • android使用多线程更新ui示例分享
  • android使用handlerthread创建线程示例
  • Android后台线程和UI线程通讯实例
  • Android提高之SurfaceView与多线程的混搭实例
  • 在Android线程池里运行代码任务实例
  • android开发教程之handle实现多线程和异步处理
  • Android中创建多线程管理器实例
  • android开发教程之使用线程实现视图平滑滚动示例
  • Android开发笔记之:深入理解多线程AsyncTask
  • Android多线程及异步处理问题详细探讨
  • 深入Android线程的相关问题解惑
  • 深入Android Handler与线程间通信ITC的详解
  • android 多线程技术应用
  • android 4.0 托管进程介绍及优先级和回收机制
  • android IPC之binder通信机制
  • Android开发之广播机制浅析
  • 解析Android应用程序运行机制
  • 详细介绍Android中回调函数机制
  • 深入理解Android组件间通信机制对面向对象特性的影响详解
  • android的消息处理机制(图文+源码分析)—Looper/Handler/Message
  • Android消息处理机制Looper和Handler详解
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • android开发教程之android的handler使用方法
  • android开发教程之handler异步更新ui
  • Android Handler的详细介绍
  • Android Handler之消息循环的深入解析
  • android Handler详细使用方法实例
  • Android开发笔记之:Handler Runnable与Thread的区别详解
  • 申请Android Map 的API Key(v2)的最新申请方式(SHA1密钥)
  • Android瀑布流实例 android_waterfall
  • Android开发需要的几点注意事项总结
  • 解析Android应用程序运行机制 iis7站长之家
  • Android访问与手机通讯相关类的介绍
  • Android网络共享软件 Android Wifi Tether
  • Android及andriod无线网络Wifi开发的几点注意事项
  • Android 图标库 Android GraphView
  • Android 2.3 下StrictMode介绍
  • 轻量级Android开发工具 Android Tools
  • Android 开发环境 Android Studio
  • IDEA的Android开发插件 idea-android
  • Android手机事件提醒 Android Notifier
  • XBMC的Android客户端 android-xbmcremote
  • Android小游戏 Android Shapes
  • Android电池监控 Android Battery Dog
  • android开发:“android:WindowTitle”没有对应项no resource
  • Android 上类似IOS 的开关控件。 Android ToggleButton
  • Android 将 android view 的位置设为右下角的解决方法
  • Android 2D游戏引擎 Android Angle
  • Android的UI工具包 android-ui-utils


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3