在做某事之前,如何正确地等待HandlerThread启动?

时间:2018-08-07 01:36:35

标签: android android-handlerthread

在“我的项目”中,有时创建的线程的启动速度不应该达到预期的速度。这种情况很少发生,但大多数情况下发生在速度较慢/较旧的手机上。

我喜欢我的主题。

class DBThread(threadName: String) : HandlerThread(threadName) {

private var mWorkerHandler: Handler? = null

    override fun onLooperPrepared() {
        super.onLooperPrepared()
        mWorkerHandler = Handler(looper)
    }

    fun createTask(task: Runnable) {
        mWorkerHandler?.post(task)
    }
}

当我使用它并调用活动时。

//this will handle db queries on background and not on main ui thread
var mDbThread: DBThread = DBThread("dbThread")

//use this to interact to main ui thread from different thread
val mUiHandler = Handler()
var mDb: LocalDatabase? = null

override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)

    mDbThread.start()
    mDb = LocalDatabase.getInstance(this)

    fetchAndSetList()

}

override fun onDestroy() {
    super.onDestroy()

    LocalDatabase.destroyInstance()
    mDbThread.quitSafely()
}


private fun fetchAndSetList(){

    mDbThread.createTask(Runnable {
        val list = getList()
        mUiHandler.post {
            // this sometimes does not trigger
            setList(list)
        }
    })
}

setList函数有时不会触发。 所以我做了这样的事情。

fun createTask(task: Runnable) {
    if(mWorkerHandler == null ){
        createTask(task)
        return
    }
    mWorkerHandler?.post(task)
}

修改后的动作似乎有效,但是我不确定这是否是一种安全的方法。预先谢谢你。

1 个答案:

答案 0 :(得分:0)

我认为mWorkerhandler为null的原因是因为Thread.start将创建新的VMThread并在VMThread中启动循环程序。整个流程是异步的,因此当实际调用onLooperPrepared时,为时已晚,因为“ fetchAndSetList”已经在尝试使用mWorkerHandler

解决方案是在HandlerThread之外创建处理程序:

Handler workerHandler;
override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)

    mDbThread.start()
    workerHandler = new Handler(mDbThread.getLooper());
    mDb = LocalDatabase.getInstance(this)

    fetchAndSetList()
}

private fun fetchAndSetList(){
    workerHandler.post(Runnable {
        val list = getList()
        mUiHandler.post {
            // this sometimes does not trigger
            setList(list)
        }
   })
}