并发安全的集合,方式使用synchronized修饰
SynchronizedList使用Collections.synchronizedList()方法创建的集合
ConcurrentlinkedDeque并发安全的队列,使用poll()方法读取并删除头部元素,读到null时即为读完了
CopyonWriteArrayList写的时候加锁,并赋值原有数组,同时扩展一个长度,放置新的元素,读的时候不加锁,读到的是未添加进来的老的数据
读 *** 作非常多时可用
Map HashTable SynchronizedHashMap并发安全的map,对方法内的代码块加synchronized锁
写的效率高于读的效率
ConcurrentSkipMap并发安全的有序map,使用跳跃表作为数据结构
ConcurrentHashMap并发安全的无序的map
读的效率高于写的效率,写的判断逻辑复杂
TreeMap有序的map与linkedHashMap不同的是treeMap用的是红黑树,linkedHashMap用的是链表和hashMap
Queueboolean offer(E e)添加元素,添加不成功返回false
peek()取出元素不会remove数据
poll()取出数据并且会remove数据
BlockingQueueput()存数据,如果队列已满会阻塞线程直到数据被take取出
take()取出数据,没有数据会阻塞线程一直等待,直到数据被put进去
linkedBlockingQueue用链表实现的BlockingQueue,无界队列,有内存就能放
ArrayBlockingQueue底层使用数组实现,属于有界队列,在队列已满的时候
add方法添加元素会抛出异常
offer方法添加元素不会报异常,会返回false,可指定添加时间
DelayQueue根据等待时间排序,等待越短的会优先被取出,使用PriorityQueue实现
SynchronousQueue容量为0,用来做任务下发(类似于Exchanger)
不能使用add()添加数据
使用put()添加数据
TransferQueue新增了transfer()方法,添加完数据库等待数据被消费
linkedTransferQueue PriorityQueue有序的队列,值越小越靠前,底层数据结构是二叉树
ConcurrentlinkedDeque并发安全的队列,使用poll()方法读取并删除头部元素,读到null时即为读完了
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)