家伙
我很多天都面临着非常奇怪的问题。我正在尝试频繁更新叠加层。所以有时我在地图上触摸时会得到“java.util.ConcurrentModificationException”,或者当地图试图更新叠加时有时会得到但是我找不到完整的线路,这个错误即将到来。
02-17 14:56:01.621: W/dalvikvm(3653): threadid=1: thread exiting with uncaught exception (group=0x40015560)
02-17 14:56:01.631: E/AndroidRuntime(3653): FATAL EXCEPTION: main
02-17 14:56:01.631: E/AndroidRuntime(3653): java.util.ConcurrentModificationException
02-17 14:56:01.631: E/AndroidRuntime(3653): at java.util.ArrayList$ArrayListIterator.next(ArrayList.java:576)
02-17 14:56:01.631: E/AndroidRuntime(3653): at com.google.android.maps.OverlayBundle.draw(OverlayBundle.java:41)
02-17 14:56:01.631: E/AndroidRuntime(3653): at com.google.android.maps.MapView.onDraw(MapView.java:530)
02-17 14:56:01.631: E/AndroidRuntime(3653): at android.view.View.draw(View.java:6880)
02-17 14:56:01.631: E/AndroidRuntime(3653): at android.view.ViewGroup.drawChild(ViewGroup.java:1646)
02-17 14:56:01.631: E/AndroidRuntime(3653): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)
02-17 14:56:01.631: E/AndroidRuntime(3653): at android.view.ViewGroup.drawChild(ViewGroup.java:1644)
02-17 14:56:01.631: E/AndroidRuntime(3653): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)
02-17 14:56:01.631: E/AndroidRuntime(3653): at android.view.View.draw(View.java:6883)
02-17 14:56:01.631: E/AndroidRuntime(3653): at android.widget.FrameLayout.draw(FrameLayout.java:357)
02-17 14:56:01.631: E/AndroidRuntime(3653): at android.view.ViewGroup.drawChild(ViewGroup.java:1646)
02-17 14:56:01.631: E/AndroidRuntime(3653): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)
02-17 14:56:01.631: E/AndroidRuntime(3653): at android.view.View.draw(View.java:6883)
02-17 14:56:01.631: E/AndroidRuntime(3653): at android.widget.FrameLayout.draw(FrameLayout.java:357)
02-17 14:56:01.631: E/AndroidRuntime(3653): at android.view.ViewGroup.drawChild(ViewGroup.java:1646)
02-17 14:56:01.631: E/AndroidRuntime(3653): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1373)
02-17 14:56:01.631: E/AndroidRuntime(3653): at android.view.View.draw(View.java:6883)
02-17 14:56:01.631: E/AndroidRuntime(3653): at android.widget.FrameLayout.draw(FrameLayout.java:357)
02-17 14:56:01.631: E/AndroidRuntime(3653): at com.android.internal.policy.impl.PhoneWindow$DecorView.draw(PhoneWindow.java:1862)
02-17 14:56:01.631: E/AndroidRuntime(3653): at android.view.ViewRoot.draw(ViewRoot.java:1522)
02-17 14:56:01.631: E/AndroidRuntime(3653): at android.view.ViewRoot.performTraversals(ViewRoot.java:1258)
02-17 14:56:01.631: E/AndroidRuntime(3653): at android.view.ViewRoot.handleMessage(ViewRoot.java:1859)
02-17 14:56:01.631: E/AndroidRuntime(3653): at android.os.Handler.dispatchMessage(Handler.java:99)
02-17 14:56:01.631: E/AndroidRuntime(3653): at android.os.Looper.loop(Looper.java:130)
02-17 14:56:01.631: E/AndroidRuntime(3653): at android.app.ActivityThread.main(ActivityThread.java:3683)
02-17 14:56:01.631: E/AndroidRuntime(3653): at java.lang.reflect.Method.invokeNative(Native Method)
02-17 14:56:01.631: E/AndroidRuntime(3653): at java.lang.reflect.Method.invoke(Method.java:507)
02-17 14:56:01.631: E/AndroidRuntime(3653): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
02-17 14:56:01.631: E/AndroidRuntime(3653): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
02-17 14:56:01.631: E/AndroidRuntime(3653): at dalvik.system.NativeStart.main(Native Method)
我正在使用Balloon Overlay
我认为它会在"mapview.getOverlay()"
上抛出错误,因为它在1秒内调用了4-5次..
谢谢,
CapDroid
这里是代码流程.. 我的线程代码....
Thread connection = new Thread(){
public void run() {
try {
while (my condition)
{
try
{
//This method should be call every seconds
updateMethod();
}
catch (Exception e)
{
e.printStackTrace();
break;
}
}
}
catch (Exception e)
{
}
}
};
这是我的updateMethod(); 在这段代码中,hashmapOverlay是HashMap,如下所示
public static Map<String,MyItemizedOverlay> hashmapOverlay;
public void updateMethod()
{
if(hashmapOverlay.containsKey(id))
{
mapview.getOverlays().remove(hashmapOnlineFriendsOverlay.get(id));
}
MyItemizedOverlay mMyItemizedOverlay = new MyItemizedOverlay(drawable, mapview);
OverlayItem overlayItem = new OverlayItem(gp,title ,snippet);
mMyItemizedOverlay.addOverlay(overlayItem);
hashmapOverlay.put(id, mMyItemizedOverlay);
addOverlayMethod(mActivity, mapView, mMyItemizedOverlay);
}
这是我的addOverlayMethod
addOverlayMethod(Activity mActivity, final MapView mapView, final Object mObject)
{
mActivity.runOnUiThread(new Runnable(){
@Override
public void run()
{
try {
MyItemizedOverlay overlay = (MyItemizedOverlay) mObject;
mapView.getOverlays().add(overlay);
} catch (Exception e)
{}
}
});
}
答案 0 :(得分:2)
为避免ConcurrentModificationException
在以下任何情况下复制您的收藏集:
new ArrayList<YourClass>(existingList)
。
答案 1 :(得分:1)
我认为您使用Thread
及其创建Concurrency
因此在您的运行方法中使用Syncronized(MainActivity.this)
....并使用向量而不是列表因为向量是同步的...其工作对我来说......
答案 2 :(得分:1)
好吧,似乎在您的updateMethod()
中,您仍然试图Update
来自Non-UI
主题的用户界面<{1}}
mapview.getOverlays().remove(hashmapOnlineFriendsOverlay.get(id));
因此,尝试在RunOnUiThread
内执行此部分代码并尝试。希望这会奏效。
UPDATE:
此外,为什么您尝试add
和remove
Overlay
所有内容,您不需要这样做只是尝试更新Overlay
和{{ 1}}它。 Have a look at this example.
答案 3 :(得分:1)
我不确定叠加管理,但是我看到它的方式,你在非UI线程(在UpdateMethod中)使用HashMap.put修改你的HashMap,当毫无疑问被迭代或使用时应用程序中的其他位置 - 可能在您移动地图时仍然请求新的叠加层。
如果您阅读docs,它会说这会导致ConcurrentModificationException。相反,请尝试使用ConcurrentHashMap,或重新构建代码以更新正在使用它的主线程上的hashmap。
答案 4 :(得分:1)
相同的方式,直到Pendingnotification List变为空。
另请注意,必须在UI Thread
中执行任何修改,而不是NonUI Thread