CopyOnWriteArraySet


CopyOnWriteArraySet

HashSet是多线程不安全的,建议使用CopyOnWriteArraySet

package com.example.juc;

import java.util.Set;
import java.util.UUID;
import java.util.concurrent.CopyOnWriteArraySet;

/**
 * HashSet和ArrayList一样有多线程不安全问题,解决方法
 * 1.Collections.synchronizedSet 效率不高,底层synchrnized实现
 * 2.CopyOnWriteArraySet 效率高,底层Lock实现
 */
public class TestSet {
    public static void main(String[] args) {
//        Set set = new HashSet<>();
//        Set set = Collections.synchronizedSet(new HashSet<>());
        Set set = new CopyOnWriteArraySet<>();
        for (int i = 0; i < 30; i++) {
            new Thread(() -> {
                set.add(UUID.randomUUID().toString().substring(0, 5));
                System.out.println(set);
            }, "" + i).start();

        }
    }
}

扩展

HashSet 底层实现是HashMap

利用HashMap的key不重复来实现的