在一个android服务,我已经创建线程(s)做一些后台任务。
我有一个线程需要在主线程的消息队列上发布某个任务的情况,例如一个可运行的。
有没有办法得到主线程的处理程序和post Message/Runnable到它从我的其他线程?
在一个android服务,我已经创建线程(s)做一些后台任务。
我有一个线程需要在主线程的消息队列上发布某个任务的情况,例如一个可运行的。
有没有办法得到主线程的处理程序和post Message/Runnable到它从我的其他线程?
当前回答
还有另一种简单的方法,如果你没有访问Context的权限。
1).从主循环程序创建一个处理程序:
Handler uiHandler = new Handler(Looper.getMainLooper());
2).实现一个可运行的接口:
Runnable runnable = new Runnable() { // your code here }
3).发布你的Runnable到uiHandler:
uiHandler.post(runnable);
这就是全部;-)享受线程的乐趣,但不要忘记同步它们。
其他回答
Kotlin 版本
当你在做某项活动时,就用
runOnUiThread {
//code that runs in main
}
当你有活动上下文,mContext然后使用
mContext.runOnUiThread {
//code that runs in main
}
当你在一个没有上下文的地方,然后使用
Handler(Looper.getMainLooper()).post {
//code that runs in main
}
public void mainWork() {
new Handler(Looper.getMainLooper()).post(new Runnable() {
@Override
public void run() {
//Add Your Code Here
}
});
}
这也可以在服务类中毫无问题地工作。
我能想到的一个方法是:
1)让UI绑定到服务。 2)暴露一个方法,就像下面一个由Binder注册你的处理程序:
public void registerHandler(Handler handler) {
mHandler = handler;
}
3)在UI线程中,绑定到服务后调用上述方法:
mBinder.registerHandler(new Handler());
4)使用服务线程中的处理程序来发布你的任务:
mHandler.post(runnable);
所以最方便的方法是:
import android.os.AsyncTask
import android.os.Handler
import android.os.Looper
object Dispatch {
fun asyncOnBackground(call: ()->Unit) {
AsyncTask.execute {
call()
}
}
fun asyncOnMain(call: ()->Unit) {
Handler(Looper.getMainLooper()).post {
call()
}
}
}
后:
Dispatch.asyncOnBackground {
val value = ...// super processing
Dispatch.asyncOnMain { completion(value)}
}
对于Kotlin,你可以使用Anko corountines:
更新
doAsync {
...
}
弃用
async(UI) {
// Code run on UI thread
// Use ref() instead of this@MyActivity
}