RSSフィードを取得中に不確定なProgressDialogを表示しようとしています。私はダイアログをポップしますが、結果が返されると直ちに強制終了します。私の疑問は、アダプタが実装され、UIを更新することです。コードは以下の通りです。私の疑惑は正しいのですか?Android Force Close on ProgressDialog
public void getRSS(String rss)
{
new GetRSS().execute(rss);
}
private class GetRSS extends AsyncTask<String, Void, Void>
{
private ProgressDialog Dialog = new ProgressDialog(View2.this);
protected void onPreExecute() {
Dialog.setMessage("Please wait...");
Dialog.show();
}
protected void onPostExecute(Void nothing)
{
Dialog.dismiss();
}
protected Void doInBackground(String... rss) {
URL feedUrl;
try
{
feedUrl = new URL(rss[0]);
SyndFeedInput input = new SyndFeedInput();
SyndFeed feed = input.build(new XmlReader(feedUrl));
List entries = feed.getEntries();
Iterator iterator = entries.listIterator();
while (iterator.hasNext())
{
SyndEntry ent = (SyndEntry) iterator.next();
String title = ent.getTitle();
//String uri = ent.getUri();
//d.add(uri);
SyndContent content = (SyndContent)ent.getContents().get(0);
d.add(content.getValue());
adapter.add(title);
}
adapter.notifyDataSetChanged();
}
catch (MalformedURLException e)
{
e.printStackTrace();
}
catch (IllegalArgumentException e)
{
e.printStackTrace();
}
catch (FeedException e)
{
e.printStackTrace();
}
catch (IOException e)
{
e.printStackTrace();
}
return null;
}
}
*/
ここにスタックダンプがあります。明らかにnotifyの呼び出しが問題です。今、私はちょうどトラブル通知呼び出しする考え出すを抱えている:
01-22 12:02:28.701: ERROR/WindowManager(571): Activity com.digthisband.dtb.jg.View2 has leaked window [email protected] that was originally added here
1月22日12:02:28.701:ERROR /ウィンドウマネージャ(571):android.view.WindowLeaked:活動com.digthisband.dtbを。 jg.View2が最初にここに追加された[email protected]ウィンドウをリークしました 01-22 12:02:28.701:ERROR/WindowManager(571):android.view.ViewRoot。 (ViewRoot.java:247) 01-22 12:02:28.701:ERROR/WindowManager(571):android.view.WindowManagerImpl.addView(WindowManagerImpl.java:148) 01-22 12:02:28.701:ERROR/WindowManager(571):android.view.WindowManagerImpl.addView(WindowManagerImpl.java:91) 01-22 12:02:28.701:ERROR/WindowManager(571): android.view.Window $ LocalWindowManager.addView(Window.java:424) 01-22 12:02:28.701:ERROR/WindowManager(571):android.app.Dialog.show(Dialog.java:241) 01-22 12:02:28.701:ERROR/WindowManager(571):com.digthisband.dtb.jg.View2 $ GetRSS.onPreExecute(View2.java:97) 01-22 12:02:28.701:ERROR/WindowManager (571):android.os.AsyncTask.execute(AsyncTask.java:391) 01-22 12:02:28.701:ERROR/WindowManager(571):com.digthisband.dtb.jg.View2.getRSS(View2 .java:87) 01-22 12:02:28.701:ERROR/WindowManager(571):com.digthisband.dtb.jg.View2.onCreate(View2.java:68) 01-22 12:02:28.701 :ERROR/WindowManager(571):android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) 01-22 12:02:28.701:ERROR/WindowManager(571):android.app.ActivityThre (17):android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679) 01-22 12:02:ad.performLaunchActivity(ActivityThread.java:2627) 01-22 12:02:28.701:ERROR/WindowManager 28.701:ERROR/WindowManager(571):android.app.ActivityThread.access $ 2300(ActivityThread.java:125) 01-22 12:02:28.701:ERROR/WindowManager(571):android.app.ActivityThread $ H .handleMessage(ActivityThread.java:2033) 01-22 12:02:28.701:ERROR/WindowManager(571):android.os.Handler.dispatchMessage(Handler.java:99) 01-22 12:02:28.701 :ERROR/WindowManager(571):android.os.Looper.loop(Looper.java:123) 01-22 12:02:28.701:ERROR/WindowManager(571):android.app.ActivityThread.main(ActivityThread .java:4627) 01-22 12:02:28.701:ERROR/WindowManager(571):java.lang.reflect。 Method.invokeNative(ネイティブメソッド) 01-22 12:02:28.701:ERROR/WindowManager(571):java.lang.reflect.Method.invoke(Method.java:521) 01-22 12:02:28.701 :ERROR/WindowManager(571):com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:868) 01-22 12:02:28.701:ERROR/WindowManager(571):at com.android .internal.os.ZygoteInit.main(ZygoteInit.java:626) 1月22日12:02:28.701:ERROR /ウィンドウマネージャ(571):dalvik.system.NativeStart.main(ネイティブメソッド)で
あなたは本当に正しいです - 私はnotifyDataSetChangedへの呼び出しを削除し、クラッシュはなくなりました。私も自分のデータを取得していません。しかしそれは始まりです... – voodoobilly
ここにダンプがあります: – voodoobilly
Heh ...まあ、はい。標準的なことは、代わりにpublishProgress()を呼び出すことです。これは順番に、notifyDataSetChanged()を呼び出すことができるUIスレッドでonProgressUpdate()を自動的に呼び出します。 onProgressUpdate()をオーバーライドする必要があります。 – Jems