Android 点滴——Handler用法总结
2015-08-19 17:59
579 查看
方法一:(java习惯,在android平台开发时这样是不行的,因为它违背了单线程模型)
刚刚开始接触android线程编程的时候,习惯好像java一样,试图用下面的代码解决问题
可以实现功能,刷新UI界面。但是这样是不行的,因为它违背了单线程模型:Android UI操作并不是线程安全的并且这些操作必须在UI线程中执行。
方法二:(Thread+Handler)
查阅了文档和apidemo后,发觉常用的方法是利用Handler来实现UI线程的更新的。
Handler来根据接收的消息,处理UI更新。Thread线程发出Handler消息,通知更新UI。
方法三:(java习惯。Android平台中,这样做是不行的,这跟Android的线程安全有关)
在Android平台中需要反复按周期执行方法可以使用Java上自带的TimerTask类,TimerTask相对于Thread来说对于资源消耗的更低,除了使用Android自带的AlarmManager使用Timer定时器是一种更好的解决方法。 我们需要引入import java.util.Timer; 和 import java.util.TimerTask;
方法四:(TimerTask + Handler)
通过配合Handler来实现timer功能的!
方法五:( Runnable + Handler.postDelayed(runnable,time) )
在Android里定时更新 UI,通常使用的是 java.util.Timer, java.util.TimerTask, android.os.Handler组合。实际上Handler 自身已经提供了定时的功能。
然后在其他地方调用
handler.post(myRunnable);
handler.post(myRunnable,time);
方法六:( HandlerThread)
刚刚开始接触android线程编程的时候,习惯好像java一样,试图用下面的代码解决问题
new Thread( new Runnable() { public void run() { myView.invalidate(); } }).start();
可以实现功能,刷新UI界面。但是这样是不行的,因为它违背了单线程模型:Android UI操作并不是线程安全的并且这些操作必须在UI线程中执行。
方法二:(Thread+Handler)
查阅了文档和apidemo后,发觉常用的方法是利用Handler来实现UI线程的更新的。
Handler来根据接收的消息,处理UI更新。Thread线程发出Handler消息,通知更新UI。
Handler myHandler = new Handler() { public void handleMessage(Message msg) { switch (msg.what) { case TestHandler.GUIUPDATEIDENTIFIER: myBounceView.invalidate(); break; } super.handleMessage(msg); } };
class myThread implements Runnable { public void run() { while (!Thread.currentThread().isInterrupted()) { Message message = new Message(); message.what = TestHandler.GUIUPDATEIDENTIFIER; TestHandler.this.myHandler.sendMessage(message); try { Thread.sleep(100); } catch (InterruptedException e) { Thread.currentThread().interrupt(); } } } }
方法三:(java习惯。Android平台中,这样做是不行的,这跟Android的线程安全有关)
在Android平台中需要反复按周期执行方法可以使用Java上自带的TimerTask类,TimerTask相对于Thread来说对于资源消耗的更低,除了使用Android自带的AlarmManager使用Timer定时器是一种更好的解决方法。 我们需要引入import java.util.Timer; 和 import java.util.TimerTask;
public class JavaTimer extends Activity { Timer timer = new Timer(); TimerTask task = new TimerTask(){ public void run() { setTitle("hear me?"); } }; public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); timer.schedule(task, 10000); } }
方法四:(TimerTask + Handler)
通过配合Handler来实现timer功能的!
public class TestTimer extends Activity { Timer timer = new Timer(); Handler handler = new Handler(){ public void handleMessage(Message msg) { switch (msg.what) { case 1: setTitle("hear me?"); break; } super.handleMessage(msg); } }; TimerTask task = new TimerTask(){ public void run() { Message message = new Message(); message.what = 1; handler.sendMessage(message); } }; public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); timer.schedule(task, 10000); } }
方法五:( Runnable + Handler.postDelayed(runnable,time) )
在Android里定时更新 UI,通常使用的是 java.util.Timer, java.util.TimerTask, android.os.Handler组合。实际上Handler 自身已经提供了定时的功能。
private Handler handler = new Handler(); private Runnable myRunnable= new Runnable() { public void run() { if (run) { handler.postDelayed(this, 1000); count++; } tvCounter.setText("Count: " + count); } };
然后在其他地方调用
handler.post(myRunnable);
handler.post(myRunnable,time);
方法六:( HandlerThread)
public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); HandlerThread hThread=new HandlerThread("myThread"); hThread.start(); myhandler myhandler=new myhandler(hThread.getLooper()); Message msg=myhandler.obtainMessage(); msg.sendToTarget();//把 Message发送到目标对象,目标对象就是生成msg的目标对象。 } class myhandler extends Handler{ public myhandler(Looper looper){ super(looper); } public void handleMessage(Message msg) { Log.e("这是新线程", "》》》》》》》》》》》》》》》》》新线程的测试"); } }
相关文章推荐
- Android重力感应飘树叶,晃动掉元宝
- Android性能优化典范-第3季
- Android性能优化典范-第2季
- android opengl es 1.0 draw text
- android 特效头疼
- android shape使用
- Android笔记:数据储存
- Android插件技术——开篇
- windows 下搭建完成的android JNI程序
- Android studio 使用总结 (乱七八糟的细节)
- Android 多线程-----AsyncTask详解
- android 万能回调接口
- Android内存分析工具(二):DDMS
- Android ImageView的scaleType属性与adjustViewBounds属性
- Android开发必知--WebView加载html5实现炫酷引导页面
- 【Android】 Android存储之 sharedpreferences (用户偏好设置)
- [转]PC客户端与Android服务端的Socket同步通信(USB)
- 零基础学习SDL开发之在Android使用SDL2.0加载字体
- android获取设备唯一标识device_token
- Android反编译教程