在“我的项目”中,有时创建的线程的启动速度不应该达到预期的速度。这种情况很少发生,但大多数情况下发生在速度较慢/较旧的手机上。
我喜欢我的主题。
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)
}
修改后的动作似乎有效,但是我不确定这是否是一种安全的方法。预先谢谢你。
答案 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)
}
})
}