赞
踩
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");
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。