Java ViewRoot$CalledFromErrorThreadException在从AsyncTask调用setAdapter()时发生异常?
调用Java ViewRoot$CalledFromErrorThreadException在从AsyncTask调用setAdapter()时发生异常?,java,android,android-asynctask,kindle-fire,Java,Android,Android Asynctask,Kindle Fire,调用listview.setAdapter(adapter)时出现此错误来自AsyncTask的onPostExecute()方法: 07-12 19:29:38.147:E/AndroidRuntime(8478):android.view.ViewRoot$CalledFromErrorThreadException:只有创建视图层次结构的原始线程才能接触其视图。 *注意:此崩溃仅在API级别10中发生,但在最新的API中不会发生(在API 17上运行良好) 这是onPostExecute(
listview.setAdapter(adapter)时出现此错误代码>来自AsyncTask的onPostExecute()
方法:
07-12 19:29:38.147:E/AndroidRuntime(8478):android.view.ViewRoot$CalledFromErrorThreadException:只有创建视图层次结构的原始线程才能接触其视图。
*注意:此崩溃仅在API级别10中发生,但在最新的API中不会发生(在API 17上运行良好)
这是onPostExecute():
asynchhelp()
如下:
public void asynchelp(String[] er){
String iamoutofnames[]=null;
for(int q = 0; q <er.length; q++){
HashMap<String, String> map = new HashMap<String, String>();
iamoutofnames=null;
int len;
if(er[q].contains("sandy")){
//calculations
map.put("col_1", iamoutofnames[len]);
}else{
//calculations
map.put("col_1", iamoutofnames[1]);
}
fillMaps.add(map);
lv.setOnItemClickListener(onListClick);
}
SimpleAdapter adapter = new SimpleAdapter(this, fillMaps, R.layout.grid_item, from, to);
lv.setAdapter(adapter);//CRASHES ON THIS LINE**************
}
public void异步帮助(字符串[]er){
字符串iamoutofnames[]=null;
对于(int q=0;q这是我在asynchhelp();
中用来解决错误的:
runOnUiThread(new Runnable() {
public void run() {
lv.setAdapter(adapter);//lv needs to be declared as final
}
});
我最好的猜测是您在后台线程上创建了ListView
,但当时没有将其添加到视图层次结构中。@commonwareListView
是在onCreate()中创建的
UI线程本身的函数。此外,此代码在API级别17上运行良好,这一定意味着API级别10中存在一些限制,我的代码正在违反这些限制。@commonware同样,当我绕过asynctask并将一些伪值传递给适配器时,它运行良好。如果从UI调用lv.setAdapter(adapter);会怎么样(runOnUiThread)线程本身?也存在此问题(在旧的Android设备上)-尽管在AsyncTask.onPostExecute()内,线程访问无效。这似乎是Android.Stack中的一个错误(以防有人感兴趣):
07-12 19:29:37.996: W/System.err(8478): android.view.ViewRoot$CalledFromWrongThreadException: Only the original thread that created a view hierarchy can touch its views.
07-12 19:29:37.996: W/System.err(8478): at android.view.ViewRoot.checkThread(ViewRoot.java:2932)
07-12 19:29:38.006: W/System.err(8478): at android.view.ViewRoot.invalidateChild(ViewRoot.java:642)
07-12 19:29:38.006: W/System.err(8478): at android.view.ViewRoot.invalidateChildInParent(ViewRoot.java:668)
07-12 19:29:38.006: W/System.err(8478): at android.view.ViewGroup.invalidateChild(ViewGroup.java:2511)
07-12 19:29:38.006: W/System.err(8478): at android.view.View.invalidate(View.java:5279)
07-12 19:29:38.006: W/System.err(8478): at android.widget.AbsListView.resetList(AbsListView.java:1150)
07-12 19:29:38.006: W/System.err(8478): at android.widget.ListView.resetList(ListView.java:511)
07-12 19:29:38.006: W/System.err(8478): at android.widget.ListView.setAdapter(ListView.java:440)
07-12 19:29:38.006: W/System.err(8478): at com.example.kiva.ListViewA.asynchelp(ListViewA.java:519)
07-12 19:29:38.006: W/System.err(8478): at com.example.kiva.ListViewA$RetreiveFeedTask.onPostExecute(ListViewA.java:1330)
07-12 19:29:38.006: W/System.err(8478): at com.example.kiva.ListViewA$RetreiveFeedTask.onPostExecute(ListViewA.java:1)
07-12 19:29:38.006: W/System.err(8478): at android.os.AsyncTask.finish(AsyncTask.java:417)
07-12 19:29:38.006: W/System.err(8478): at android.os.AsyncTask.access$300(AsyncTask.java:127)
07-12 19:29:38.006: W/System.err(8478): at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:429)
07-12 19:29:38.016: W/System.err(8478): at android.os.Handler.dispatchMessage(Handler.java:99)
07-12 19:29:38.016: W/System.err(8478): at android.os.Looper.loop(Looper.java:130)
07-12 19:29:38.016: W/System.err(8478): at android.os.HandlerThread.run(HandlerThread.java:60)
07-12 19:29:40.096: W/FlurryAgent(8478): onEndSession called without context from corresponding onStartSession
07-12 19:29:40.206: E/WindowManager(8478): Activity com.example.kiva.ListViewA has leaked window com.android.internal.policy.impl.PhoneWindow$DecorView@40631600 that was originally added here
07-12 19:29:40.206: E/WindowManager(8478): android.view.WindowLeaked: Activity com.example.kiva.ListViewA has leaked window com.android.internal.policy.impl.PhoneWindow$DecorView@40631600 that was originally added here
07-12 19:29:40.206: E/WindowManager(8478): at android.view.ViewRoot.<init>(ViewRoot.java:258)
07-12 19:29:40.206: E/WindowManager(8478): at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:148)
07-12 19:29:40.206: E/WindowManager(8478): at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:91)
07-12 19:29:40.206: E/WindowManager(8478): at android.view.Window$LocalWindowManager.addView(Window.java:424)
07-12 19:29:40.206: E/WindowManager(8478): at android.app.Dialog.show(Dialog.java:241)
07-12 19:29:40.206: E/WindowManager(8478): at android.app.ProgressDialog.show(ProgressDialog.java:107)
07-12 19:29:40.206: E/WindowManager(8478): at android.app.ProgressDialog.show(ProgressDialog.java:90)
07-12 19:29:40.206: E/WindowManager(8478): at com.example.kiva.ListViewA.topfeeds(ListViewA.java:1598)
07-12 19:29:40.206: E/WindowManager(8478): at com.example.kiva.ListViewA.onCreate(ListViewA.java:278)
07-12 19:29:40.206: E/WindowManager(8478): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
07-12 19:29:40.206: E/WindowManager(8478): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611)
07-12 19:29:40.206: E/WindowManager(8478): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
07-12 19:29:40.206: E/WindowManager(8478): at android.app.ActivityThread.access$1500(ActivityThread.java:117)
07-12 19:29:40.206: E/WindowManager(8478): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
07-12 19:29:40.206: E/WindowManager(8478): at android.os.Handler.dispatchMessage(Handler.java:99)
07-12 19:29:40.206: E/WindowManager(8478): at android.os.Looper.loop(Looper.java:130)
07-12 19:29:40.206: E/WindowManager(8478): at android.app.ActivityThread.main(ActivityThread.java:3683)
07-12 19:29:40.206: E/WindowManager(8478): at java.lang.reflect.Method.invokeNative(Native Method)
07-12 19:29:40.206: E/WindowManager(8478): at java.lang.reflect.Method.invoke(Method.java:507)
07-12 19:29:40.206: E/WindowManager(8478): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
07-12 19:29:40.206: E/WindowManager(8478): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
07-12 19:29:40.206: E/WindowManager(8478): at dalvik.system.NativeStart.main(Native Method)
runOnUiThread(new Runnable() {
public void run() {
lv.setAdapter(adapter);//lv needs to be declared as final
}
});