まず第一にCommonsWare
、この素晴らしいコンポーネントに感謝します。しかし、私は時々私に悲しみを与えてきた問題を抱えています。つまり、-> java.lang.IllegalStateException:アダプターの内容は変更されましたが、ListViewは通知を受信しませんでした。アダプタのコンテンツがバックグラウンドスレッドからではなく、UIスレッドからのみ変更されていることを確認してください。
上記は私が時々受けるエラーですが、そうでないこともあります。以下は私のコードです。
protected boolean cacheInBackground() {
JSONObject json = null;
if(results != null)
results.clear();
results = new ArrayList<DataSource>();// results is the global variable which is List<DataSource> results; and initialized it here.
List<NameValuePair> params = new ArrayList<NameValuePair>();
params.add(new BasicNameValuePair("postdata",passeddata));
params.add(new BasicNameValuePair("currentpage", (++index)+""));
json = jParser.makeHttpRequest(urlphp, "POST", params); // Here is the line that makes http request for paginated results based on index and gets the response.
try {
int success = json.getInt("success");
if (success == 1) {
rowcount = json.getInt("numrows");
Log.d("row count value is>>>>",""+rowcount); // Here rowcount is the total rows in the database
products = json.getJSONArray("products");
// looping through All Products
for (int i = 0; i < products.length(); i++) {
JSONObject c = products.getJSONObject(i);
// Storing each json item in variable
String id = c.getString(ID);
String price = c.getString(PRICE);
String name = c.getString(NAME);
DataSource data = new DataSource(id,name,price);
results.add(data);
}
}else{
// product not found
successpass = success;
message = json.getString("message");
return false;
}
} catch (JSONException e) {
e.printStackTrace();
}
return(getWrappedAdapter().getCount()<rowcount);
}
@Override
protected void appendCachedData() {
if (getWrappedAdapter().getCount()<rowcount) {
@SuppressWarnings("unchecked")
CustomListAdapter adapter = (CustomListAdapter)getWrappedAdapter();
//ArrayAdapter<Integer> a=(ArrayAdapter<Integer>)getWrappedAdapter();
for (DataSource d : results){
adapter.add(d);
}
}else{
}
}
コードでわかるように、データをBeanクラスオブジェクトに格納してから、その各オブジェクトをListに格納しています。詳細をリストに表示するためにCustomListViewを実装しました。
ただし、上記のエラーが発生する場合と発生しない場合があります。これをたくさん検索して、これと、このような他の一般的なアダプタの問題などを見つけましたが、クリックしなくても、呼び出しなくても、このエラーが発生します。私のコードでわかるように、notifyDataSetChanged()を呼び出したことはありませんが、なぜこのエラーが発生するのですか?実装コーディングに何か問題がありますか?誰かが私がこの問題を解決するのを手伝ってくれますか?このコンポーネントをアプリケーションに深く統合したので、代替案を探すのが怖いです。placeholder
notifyDataSetChanged()
以下はスタックトレースです。
03-13 16:12:07.662: E/AndroidRuntime(494): FATAL EXCEPTION: main
03-13 16:12:07.662: E/AndroidRuntime(494): java.lang.IllegalStateException: The content of the adapter has changed but ListView did not receive a notification. Make sure the content of your adapter is not modified from a background thread, but only from the UI thread. [in ListView(2130968671, class android.widget.ListView) with Adapter(class com.example.onlinedata.ORAdsList$CustomisedEndlessAdapter)]
03-13 16:12:07.662: E/AndroidRuntime(494): at android.widget.ListView.layoutChildren(ListView.java:1492)
03-13 16:12:07.662: E/AndroidRuntime(494): at android.widget.AbsListView.onLayout(AbsListView.java:1147)
03-13 16:12:07.662: E/AndroidRuntime(494): at android.view.View.layout(View.java:7035)
03-13 16:12:07.662: E/AndroidRuntime(494): at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1249)
03-13 16:12:07.662: E/AndroidRuntime(494): at android.widget.LinearLayout.layoutVertical(LinearLayout.java:1125)
03-13 16:12:07.662: E/AndroidRuntime(494): at android.widget.LinearLayout.onLayout(LinearLayout.java:1042)
03-13 16:12:07.662: E/AndroidRuntime(494): at android.view.View.layout(View.java:7035)
03-13 16:12:07.662: E/AndroidRuntime(494): at android.widget.FrameLayout.onLayout(FrameLayout.java:333)
03-13 16:12:07.662: E/AndroidRuntime(494): at android.view.View.layout(View.java:7035)
03-13 16:12:07.662: E/AndroidRuntime(494): at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1249)
03-13 16:12:07.662: E/AndroidRuntime(494): at android.widget.LinearLayout.layoutVertical(LinearLayout.java:1125)
03-13 16:12:07.662: E/AndroidRuntime(494): at android.widget.LinearLayout.onLayout(LinearLayout.java:1042)
03-13 16:12:07.662: E/AndroidRuntime(494): at android.view.View.layout(View.java:7035)
03-13 16:12:07.662: E/AndroidRuntime(494): at android.widget.FrameLayout.onLayout(FrameLayout.java:333)
03-13 16:12:07.662: E/AndroidRuntime(494): at android.view.View.layout(View.java:7035)
03-13 16:12:07.662: E/AndroidRuntime(494): at android.widget.FrameLayout.onLayout(FrameLayout.java:333)
03-13 16:12:07.662: E/AndroidRuntime(494): at android.view.View.layout(View.java:7035)
03-13 16:12:07.662: E/AndroidRuntime(494): at android.view.ViewRoot.performTraversals(ViewRoot.java:1045)
03-13 16:12:07.662: E/AndroidRuntime(494): at android.view.ViewRoot.handleMessage(ViewRoot.java:1727)
03-13 16:12:07.662: E/AndroidRuntime(494): at android.os.Handler.dispatchMessage(Handler.java:99)
03-13 16:12:07.662: E/AndroidRuntime(494): at android.os.Looper.loop(Looper.java:123)
03-13 16:12:07.662: E/AndroidRuntime(494): at android.app.ActivityThread.main(ActivityThread.java:4627)
03-13 16:12:07.662: E/AndroidRuntime(494): at java.lang.reflect.Method.invokeNative(Native Method)
03-13 16:12:07.662: E/AndroidRuntime(494): at java.lang.reflect.Method.invoke(Method.java:521)
03-13 16:12:07.662: E/AndroidRuntime(494): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
03-13 16:12:07.662: E/AndroidRuntime(494): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
03-13 16:12:07.662: E/AndroidRuntime(494): at dalvik.system.NativeStart.main(Native Method)