0

Eclipse でデバッグしている Android Google マップ アプリがあります。次のエラーが表示されます。

    12-14 16:19:50.106: E/AndroidRuntime(2487): FATAL EXCEPTION: main
12-14 16:19:50.106: E/AndroidRuntime(2487): java.util.ConcurrentModificationException
12-14 16:19:50.106: E/AndroidRuntime(2487):     at java.util.ArrayList$ArrayListIterator.next(ArrayList.java:573)
12-14 16:19:50.106: E/AndroidRuntime(2487):     at com.google.android.maps.OverlayBundle.draw(OverlayBundle.java:41)
12-14 16:19:50.106: E/AndroidRuntime(2487):     at com.google.android.maps.MapView.onDraw(MapView.java:494)
12-14 16:19:50.106: E/AndroidRuntime(2487):     at android.view.View.draw(View.java:6740)
12-14 16:19:50.106: E/AndroidRuntime(2487):     at android.view.ViewGroup.drawChild(ViewGroup.java:1640)
12-14 16:19:50.106: E/AndroidRuntime(2487):     at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1367)
12-14 16:19:50.106: E/AndroidRuntime(2487):     at android.view.ViewGroup.drawChild(ViewGroup.java:1638)
12-14 16:19:50.106: E/AndroidRuntime(2487):     at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1367)
12-14 16:19:50.106: E/AndroidRuntime(2487):     at android.view.View.draw(View.java:6743)
12-14 16:19:50.106: E/AndroidRuntime(2487):     at android.widget.FrameLayout.draw(FrameLayout.java:352)
12-14 16:19:50.106: E/AndroidRuntime(2487):     at android.view.ViewGroup.drawChild(ViewGroup.java:1640)
12-14 16:19:50.106: E/AndroidRuntime(2487):     at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1367)
12-14 16:19:50.106: E/AndroidRuntime(2487):     at android.view.ViewGroup.drawChild(ViewGroup.java:1638)
12-14 16:19:50.106: E/AndroidRuntime(2487):     at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1367)
12-14 16:19:50.106: E/AndroidRuntime(2487):     at android.view.View.draw(View.java:6743)
12-14 16:19:50.106: E/AndroidRuntime(2487):     at android.widget.FrameLayout.draw(FrameLayout.java:352)
12-14 16:19:50.106: E/AndroidRuntime(2487):     at com.android.internal.policy.impl.PhoneWindow$DecorView.draw(PhoneWindow.java:1842)
12-14 16:19:50.106: E/AndroidRuntime(2487):     at android.view.ViewRoot.draw(ViewRoot.java:1407)
12-14 16:19:50.106: E/AndroidRuntime(2487):     at android.view.ViewRoot.performTraversals(ViewRoot.java:1163)
12-14 16:19:50.106: E/AndroidRuntime(2487):     at android.view.ViewRoot.handleMessage(ViewRoot.java:1727)
12-14 16:19:50.106: E/AndroidRuntime(2487):     at android.os.Handler.dispatchMessage(Handler.java:99)
12-14 16:19:50.106: E/AndroidRuntime(2487):     at android.os.Looper.loop(Looper.java:123)
12-14 16:19:50.106: E/AndroidRuntime(2487):     at android.app.ActivityThread.main(ActivityThread.java:4627)
12-14 16:19:50.106: E/AndroidRuntime(2487):     at java.lang.reflect.Method.invokeNative(Native Method)
12-14 16:19:50.106: E/AndroidRuntime(2487):     at java.lang.reflect.Method.invoke(Method.java:521)
12-14 16:19:50.106: E/AndroidRuntime(2487):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:858)
12-14 16:19:50.106: E/AndroidRuntime(2487):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
12-14 16:19:50.106: E/AndroidRuntime(2487):     at dalvik.system.NativeStart.main(Native Method)

私はイテレータを明示的に使用することはありません (私のコードには何もありませんが、明らかに一部の呼び出しにはイテレータが含まれています) Collections.synchronizedList。 . 私のコードベースで何がこれを引き起こすのか分からないので、コードスニペットを実際に投稿することはできません. 他の「通常の」原因を知っている人はいますか? または、logcat の出力から意味のある場所を取得する方法 (私が知る限り、ファイル参照はライブラリ ファイルのみです)。

4

1 に答える 1

2

自動生成またはライブラリコードだと思いますか?

ライブラリコードです。

私が書いていないコードに問題を引き起こす可能性のあることは何ですか?

バックグラウンド スレッドでオーバーレイを追加または削除するなど、メイン アプリケーション スレッドで反復処理されているバックグラウンド スレッドでコレクションを変更しています。

残念ながら、Android 向け Google Maps API の従来のバージョンも V2 バージョンもオープン ソースではないため、スタック トレースから何が起こっているのかを正確に判断することは困難です。私の推測では、バックグラウンド スレッドでオーバーレイを追加または削除していると思われます。

于 2012-12-14T21:35:03.080 に答える