【发布时间】:2019-09-24 16:55:21
【问题描述】:
编辑:正如 Mike M. 和 Vladyslav Matviienko 和 Vivek Mishra 指出的那样
new Runnable().run();
不是一个单独的线程。谢谢各位:)
编辑结束。
当我启动一个使用单独线程与服务器通信的新 Activity 时,它会冻结。
我用
开始一个新的活动Intent i = new Intent(this, AcmActivity.class);
startActivityForResult(i, acm_ui);
然后我在onCreate() 中对我的客户端类运行异步调用
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
this.setContentView(R.layout.acm);
//get the client implementation
ClientImpl client = ServiceManager.getService(ClientImpl.class);
client.getData(new PrivateClientCallback())
}
private class PrivateClientCallback implements GeneralCallback {
@Override
public void ok(final String response) {
runOnUiThread(new Runnable() {
@Override
public void run() {
updateSomeView(response);
}
});
}
}
ClientImpl.getData() 看起来像这样:
public synchronized void getData(GeneralCallback cb) {
new Runnable() {
@Override
public void run() {
//allow networking within this Thread
//read more here: https://stackoverflow.com/questions/25093546/android-os-networkonmainthreadexception-at-android-os-strictmodeandroidblockgua
if (android.os.Build.VERSION.SDK_INT > 9) {
StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build();
StrictMode.setThreadPolicy(policy);
}
//send some stuff to server and use the Callback
String stuff = someStuff();
cb.ok(stuff);
}.run();
}
不幸的是,我的 Activity 冻结,直到来自服务器的调用返回。
我希望 Activity 启动并且当服务器响应更新其视图时,不幸的是这不是发生的情况。我不知道为什么。
【问题讨论】:
-
这不是一个单独的线程。你只是在当前线程上运行新的
Runnable。 -
那不是一个线程,那只是一个可运行的,你在创建后立即在主线程上运行。
-
Runnable.run()只是在当前线程上调用run()方法。
标签: android multithreading android-activity client