本管理器优点:
1.单页面来说,handlerThread作为主要管理方式,一个线程复用,对性能影响小
2.简化代码,一句代码即可开启一个异步任务,一句代码把异步结果传给UI线程
本管理器缺点:
1.由于单线程串行处理任务,有阻塞情况会影响其他任务。
2.每个activity一个管理器(一个线程),当连续开启多个activity的时候,同样对性能影响较大,有OOM风险。
以前写项目的时候,都是直接new Thread()来创建线程,这样写项目后期非常不利于维护,然后考虑是否能写一个类专门用来管理线程呢?
###首先我们需要创建一个线程:
private HandlerThread mHandlerThread;
public void oncreate() {
this.mHandlerThread =
new HandlerThread("activity worker:" + this.getClass().getSimpleName());
this.mHandlerThread.start();
}
###第二我们线程管理器只是管理线程,不进行具体的逻辑操作,那么就用到了Handler机制:
先创建一个UiHandler:
private static class UiHandler extends Handler {
private HandlerManager manager;
public UiHandler(HandlerManager manager) {
this.manager = manager;
}
public void handleMessage(Message msg) {
super.handleMessage(msg);
if(manager != null) {
//调用处理业务代码
}
}
}
由于Handler为静态内部类,与外部类并无直接联系,这样处理容易产生内存泄漏,manager对象无法释放,那么就要介入弱引用来处理该代码(也可以用软引用):
private static class UiHandler extends Handler {
private WeakReference<HandlerManager> mActivityReference;
public UiHandler(HandlerManager manager) {
this.mActivityReference = new WeakReference(manager);
}
public void handleMessage(Message msg) {
super.handleMessage(msg);
//调用处理业务代码
}
}
}
同理还有创建一个异步线程BackgroundHandler,需要注意的是创建该Handler需要把新创建的线程looper传递过去:
private static class BackgroundHandler extends Handler {
private WeakReference<HandlerManager> mActivityReference;
BackgroundHandler(HandlerManager manager, Looper looper) {
super(looper);
this.mActivityReference = new WeakReference(manager);
}
//发送消息
public void handleMessage(Message msg) {
super.handleMessage(msg);
//调用处理业务代码
}
}
}
这两个Handler我们需要在线程创建的时候就创建,所以OnCreate方法要这样改:
public void oncreate() {
this.mHandlerThread = new HandlerThread("activity worker:" + this.getClass().getSimpleName());
this.mHandlerThread.start();
this.mBackgroundHandler
= new BackgroundHandler(this, this.mHandlerThread.getLooper());
this.mUiHandler = new UiHandler(this);
}
###第三我们就要发送消息了,先理清逻辑:
1.通过消息通知Manager有异步请求。
2.Manager给BackgroundHandler发消息让他处理异步逻辑。
3.BackgroundHandler处理异步逻辑,并把处理结果返回给Manager。
4.Manager拿到处理结果发消息给UiHandler。
5.责任人(UiHandler)处理最后逻辑。
1.接收异步请求方法:
public void sendBackgroundMessage(int what, Object object) {
Message message = this.obtainBackgroundMessage();
message.what = what;
message.obj = object;