1、ConcurrentHashMap
:这是一个线程安全的 HashMap。与 Hashtable
不同的是,它支持完全并发的读取,并且线程安全的更新可以比 Hashtable
有更高的并发性
ConcurrentHashMap<String, String> concurrentHashMap = new ConcurrentHashMap<>();
concurrentHashMap.put("key", "value");
String value = concurrentHashMap.get("key");
2、CopyOnWriteArrayList
:这是一个线程安全的 List,适用于读操作远多于写操作的场景,因为每一次修改(增加/移除)都会复制一份新的数据。
CopyOnWriteArrayList<String> copyOnWriteArrayList = new CopyOnWriteArrayList<>();
copyOnWriteArrayList.add("A");
String element = copyOnWriteArrayList.get(0);
3、ConcurrentLinkedQueue
:一个线程安全的无边界队列,它实现了一个基于链表的非阻塞有序队列。
ConcurrentLinkedQueue<String> concurrentLinkedQueue = new ConcurrentLinkedQueue<>();
concurrentLinkedQueue.add("A");
String element = concurrentLinkedQueue.poll();
4、LinkedBlockingQueue
:它是一个基于链表的线程安全队列,非常适合做生产者消费者场景。
LinkedBlockingQueue<String> linkedBlockingQueue = new LinkedBlockingQueue<>();
linkedBlockingQueue.put("A");
String element = linkedBlockingQueue.take();
5、ArrayBlockingQueue
:这是一个有边界的阻塞队列,它的内部实现是一个数组。当队列满时,如果再往队列中插入元素,队列会阻塞生产者线程,直到队列有空闲空间。反之如果当队列为空时,消费者线程试图从队列中取出元素,队列会阻塞消费者线程,直到队列变得可用。
ArrayBlockingQueue<String> arrayBlockingQueue = new ArrayBlockingQueue<>(5);
arrayBlockingQueue.put("A");
String element = arrayBlockingQueue.take();
6、DelayQueue
:一个时间延迟队列,只有当延迟期满时才能从队列中取元素。
DelayQueue<DelayElement> delayQueue = new DelayQueue<>();
delayQueue.put(new DelayElement("item", 1000));
DelayElement element = delayQueue.take();
7、ConcurrentSkipListMap
:线程安全的有序的哈希表,适用于高并发的场景。
ConcurrentSkipListMap<String, String> concurrentSkipListMap = new ConcurrentSkipListMap<>();
concurrentSkipListMap.put("key", "value");
String value = concurrentSkipListMap.get("key");