集合类不安全之并发修改异常

1.首先运行这两段代码会抛出一个java.util.ConcurrentModificationException的异常

public class ContainerNotSafeDemo {
    public static void main(String[] args) {
        List<String> list = new ArrayList<>();
        for (int i = 0; i < 30; i++) {
            new Thread(() -> {
                list.add(UUID.randomUUID().toString().substring(0, 8));
                System.out.println(list);
            }, "线程--"+i).start();
        }
    }
}
public class IteratorNotSafeDemo {
    public static void main(String[] args) {
        List<String> list = new ArrayList<>();
        list.add("zzz");
        Iterator<String> iterator = list.iterator();
        while (iterator.hasNext()) {
            String next = iterator.next();
            if ("zzz".equals(next)) {
                list.remove(next);
            }
        }
    }
}

多线程给list添加值会导致ConcurrentModificationException; 当list迭代中去移除list中的元素时也会导致ConcurrentModificationException。

2.线程不安全问题的解决方法:

  a.把ArrayList换成Vector集合(vector.add()方法中由synchronized修饰)

  b.使用Collections.synchronizedList(new ArrayList());

  c.使用CopyOnWriteArrayList类(写时复制)

 

3.Set的线程不安全?

与List的线程安全一样:java.util.ConcurrentModificationException

解决方式:

  a.Collections.synchronizedSet(new HashSet());

  b.使用CopyOnWriteHashSet

 4.HashSet的底层原理?

  底层使用HashMap实现,HashSet的value就是HashMap的key值,Map中所有的key值都是一个PRESENT的Object常量

 

  5.Map的线程不安全?

与List和Set一样:java.util.ConcurrentModificationException

解决方式:

  a.Collections.synchronizedMap(new HashMap());

  b.使用ConcurrentHashMap

posted @ 2021-07-02 03:27  一柒微笑  阅读(62)  评论(0编辑  收藏  举报