目录
Handler:
相关文章:
一、什么是Handler?
二、Handler的使用方法
三、Handler机制的原理
四、Handler引起的内存泄漏以及解决办法
AsyncTask:
相关视频:
一、什么是AsyncTask
二、AsyncTask的使用方法
三、AsyncTask的内部原理
四、AsyncTask的注意事项
HandlerThread:
一、HandlerThread产生背景
二、HandlerThread的特点
三、HandlerThread源码分析
IntentService:
一、IntentService是什么?
二、IntentService使用方法
三、IntentService源码解析
Handler的基本用法(源码解析 基于nate视频)
Android面试题:Handler
点击页面上的按钮后更新TextView的内容,谈谈你的理解?(Alvin)
参照源码自己手写Handler
Handler通常被我们用来做主线程与子线程之间的通信工具,它的应用非常广泛,可以说只要有异步线程与主线程通信的地方就一定会有 Handler。
用一句话概括Handler,并简述其原理
原因:静态内部类持有外部类的匿名引用,导致外部activity无法释放
解决办法:
1、把handler改为静态内部类;
2、handler内部持有外部activity的弱引用;
3、在activity的onDestory方法中调用handler.removeCallback()
public class HandlerLeakActivity extends AppCompatActivity {
private static class MyHandler extends Handler {
private final WeakReference mActivity;
public MyHandler(HandlerLeakActivity activity) {
mActivity = new WeakReference(activity);
}
@Override
public void handleMessage(Message msg) {
HandlerLeakActivity activity = mActivity.get();
if (activity != null) {
//...
}
}
}
private final MyHandler myHandler = new MyHandler(this);
private static final Runnable mRunnable = new Runnable() {
@Override
public void run() {
}
};
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_handler_leak);
myHandler.postDelayed(mRunnable, 1000 * 60 * 10);
finish();
}
@Override
protected void onDestroy() {
super.onDestroy();
myHandler.removeCallbacks(mRunnable);
}
}
Android必学-AsyncTask基础
相关文章:
AsyncTask相关知识
深入理解AsyncTask
它本质上就是一个封装了线程池和Handler的异步框架
AsyncTask相关知识
1、AsyncTask的本质是一个静态的线程池,AsyncTask派生出的子类可以实现不同的异步任务,这些任务都是提交到静态的线程池中执行。
2、线程池中的工作线程执行doInBackground(mParams)方法执行异步任务
3、当任务状态改变之后,工作线程会向UI线程发送消息,AsyncTask内部的InternalHandler相应这些消息,并调用相关的回调函数
1、内存泄漏
2、生命周期
3、结果丢失
4、并行or串行
一般来讲,如果遇到耗时操作,就需要开启Thread子线程进行耗时操作。这个任务结束后,又有耗时任务呢?那就又得开启Thread了。但是,多次创建和销毁线程是很消耗系统资源的。这种情况下,我们就需要考虑HandlerThread了。
HandlerThread在本质上是Handler + Thread + Looper。
1、HandlerThread在本质上是一个线程类,它继承了Thread;
2、HandlerThread有自己的内部Looper对象,可以进行Looper循环;
3、通过获取HandlerThread的Looper对象传递给Handler对象,可以在handlerMessage方法中执行异步任务;
4、优点是不会有阻塞,减少了对性能的消耗,缺点是不能同时进行多任务的处理,需要等待,效率较低;
5、与线程池注重并发不同,HandlerThread是一个串行队列,HandlerThread背后只有一个线程。
IntentService是继承Service(优先级比Service高)并处理异步请求的一个类,在IntentService内有一个工作线程来处理耗时操作,启动IntentService的方式和启动传统的Service一样,同时,当任务执行完成后,IntentService会自动停止,而不需要我们手动去控制或stopSelf()。另外可以启动IntentService多次,二每一个耗时操作会以工作队列的方式在IntentService的onHandlerIntent回调方法中执行,并且,每次只会执行一个工作线程,执行完第一个再执行第二个。
创建IntentService时,只需要实现onHandleIntent和构造方法,onHandleIntent为异步方法,可以执行耗时操作