Android View.setVisibility中的java.util.ConcurrentModificationException

Android View.setVisibility中的java.util.ConcurrentModificationException,android,view,drag-and-drop,Android,View,Drag And Drop,我正在实现视图的拖放。开始拖动时,我将视图的可见性设置为不可见,然后,如果拖动被中断-返回到可见: public boolean onTouch(View v, MotionEvent event) { if (event.getAction() == MotionEvent.ACTION_DOWN) { // Skipped some code boolean dragStarted = v.startDrag(data, shadowBuilder,

我正在实现视图的拖放。开始拖动时,我将视图的可见性设置为
不可见
,然后,如果拖动被中断-返回到
可见

public boolean onTouch(View v, MotionEvent event) {
    if (event.getAction() == MotionEvent.ACTION_DOWN) {
        // Skipped some code
        boolean dragStarted = v.startDrag(data, shadowBuilder, v, 0);

        if (dragStarted) {
            v.setVisibility(View.INVISIBLE)
        }
    }
}
以及:

当调用“Drag ended”事件时,我得到一个异常:

E/AndroidRuntime(7118): FATAL EXCEPTION: main 
E/AndroidRuntime(7118): java.util.ConcurrentModificationException 
E/AndroidRuntime(7118):     at java.util.HashMap$HashIterator.nextEntry(HashMap.java:792)
E/AndroidRuntime(7118):     at java.util.HashMap$KeyIterator.next(HashMap.java:819) 
E/AndroidRuntime(7118):     at android.view.ViewGroup.dispatchDragEvent(ViewGroup.java:1046)
E/AndroidRuntime(7118):     at android.view.ViewGroup.dispatchDragEvent(ViewGroup.java:1048)
E/AndroidRuntime(7118):     at android.view.ViewGroup.dispatchDragEvent(ViewGroup.java:1048)
E/AndroidRuntime(7118):     at android.view.ViewGroup.dispatchDragEvent(ViewGroup.java:1048)
E/AndroidRuntime(7118):     at android.view.ViewRootImpl.handleDragEvent(ViewRootImpl.java:3471)
E/AndroidRuntime(7118):     at android.view.ViewRootImpl.handleMessage(ViewRootImpl.java:2620)
E/AndroidRuntime(7118):     at android.os.Handler.dispatchMessage(Handler.java:99) 
E/AndroidRuntime(7118):     at android.os.Looper.loop(Looper.java:137) 
E/AndroidRuntime(7118):     at android.app.ActivityThread.main(ActivityThread.java:4575)
E/AndroidRuntime(7118):     at java.lang.reflect.Method.invokeNative(Native Method) 
E/AndroidRuntime(7118):     at java.lang.reflect.Method.invoke(Method.java:511)
E/AndroidRuntime(7118):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:789)
E/AndroidRuntime(7118):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:556)
E/AndroidRuntime(7118):     at dalvik.system.NativeStart.main(NativeMethod)
为什么以及如何修复它?

可能会有所帮助。在给定的链接中,这里说:使用
DragEvent.ACTION\u DRAG\u ENDED
而不是
DragEvent.ACTION\u DROP

您可以试试这个

if (event.getAction() == DragEvent.ACTION_DRAG_ENDED) {
    final View droppedView = (View) event.getLocalState();
    droppedView.post(new Runnable(){
        @Override
        public void run() {
            droppedView.setVisibility(View.VISIBLE);
        }
    });
}
看起来Android本身正试图在您结束拖动的同时访问视图状态

编辑

更精确的解释。通过设置
setVisibility()
,您将从Android内部视图集合中包括或排除
视图
,这些视图应响应拖动事件。此集合在分派拖动事件期间使用,因此,通过尝试
设置可见性
(换句话说,尝试修改拖动事件的侦听器),您将导致
ConcurrentModificationException

,最好的方法是:

    view.post(new Runnable() {
  public void run() {
    view.setVisibility(View.VISIBLE);
  }
});
如果我们使用:

 if (event.getAction() == DragEvent.ACTION_DRAG_ENDED) {
    final View droppedView = (View) event.getLocalState();
    droppedView.post(new Runnable(){
        @Override
        public void run() {
            droppedView.setVisibility(View.VISIBLE);
        }
    });
}

您仍将获得force close Null.pointer

我需要处理取消拖放,当视图没有被删除。只是一个想法,但你有没有尝试过API演示?他们有一个很好的拖放示例。只需玩它,并在您希望的时候更改可见性。由于我没有使用API11+的设备,我无法检查我所做的任何事情是否有帮助(emulator是不够的,因为它有时会给出错误的结果),为什么在插入或删除iterable的某些元素时,在迭代该元素时,会发生此异常。但它似乎是android中的一个bug。try
droppedView.post(new Runnable(){public void run(){droppedView.setVisibility(View.VISIBLE);})您将需要进行droppedView finalI,因为您已经编写了一些异常发生的解释
 if (event.getAction() == DragEvent.ACTION_DRAG_ENDED) {
    final View droppedView = (View) event.getLocalState();
    droppedView.post(new Runnable(){
        @Override
        public void run() {
            droppedView.setVisibility(View.VISIBLE);
        }
    });
}