HandlerThread和IntentService

HandlerThread

源码解析

public class HandlerThread extends Thread {
    @Override
    public void run() {
        mTid = Process.myTid();
        Looper.prepare();
        synchronized (this) {
            mLooper = Looper.myLooper();
            notifyAll();
        }
        Process.setThreadPriority(mPriority);
        onLooperPrepared();
        Looper.loop();
        mTid = -1;
    }
}

HandlerThread继承自Thread,里面封装了在Tread启动时自动开启一个looper,这样我们再和Thread进行通
信的时候就能直接拿到这个Looper

如何使用

下面看一下具体使用:

HandlerThread handlerThread = new HandlerThread("Thread1");
handlerThread.start();
Handler handler = new Handler(handlerThread.getLooper());
handler.post(new Runnable() {
    @Override
    public void run() {
        System.out.println(Thread.currentThread().getName());
    }
});

handlerThread1Handler,所以Runnable会运行在Thread1线程中,这样就能完成线程的切换。其实这种方式和AsyncTask实现线程切换效果是一样的,相比AsyncTask这种方式可读性更高,使用也相对简单,也是我平时单线程切换最常用的方式。

IntentService

源码解析

public abstract class IntentService extends Service {
    private volatile Looper mServiceLooper;
    @UnsupportedAppUsage
    private volatile ServiceHandler mServiceHandler;

    private final class ServiceHandler extends Handler {
        public ServiceHandler(Looper looper) {
            super(looper);
        }

        @Override
        public void handleMessage(Message msg) {
            onHandleIntent((Intent)msg.obj);
            stopSelf(msg.arg1);
        }
    }

    @Override
    public void onCreate() {
        super.onCreate();
        HandlerThread thread = new HandlerThread("IntentService[" + mName + "]");
        thread.start();

        mServiceLooper = thread.getLooper();
        mServiceHandler = new ServiceHandler(mServiceLooper);
    }

    @Override
    public void onStart(@Nullable Intent intent, int startId) {
        Message msg = mServiceHandler.obtainMessage();
        msg.arg1 = startId;
        msg.obj = intent;
        mServiceHandler.sendMessage(msg);
    }
    
    @WorkerThread
    protected abstract void onHandleIntent(@Nullable Intent intent);
}

IntentService的封装也非常简单,主要用来在后台异步完成一些耗时任务,所以继承自Service,在服务创建的时候会创建一个并启动HandlerThread,然后创建一个Handler来处理异步任务,异步任务处理完成后会结束服务。

如何使用

public class DownloadService extends IntentService {
    public DownloadService(String name) {
        super(name);
    }

    @Override
    protected void onHandleIntent(@Nullable Intent intent) {
        // TODO: 2023/6/14 根据Intent传参做相应的处理 
    }
}

别忘了在manifest中注册service

<service android:name=".DownloadService"></service>
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值