134 并发容器类~list set queue

Posted windghost

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了134 并发容器类~list set queue相关的知识,希望对你有一定的参考价值。

arraylist:

     底层object数组,

     ensureCapcityInternal 判断是否数组扩容

 

copyonwritearraylist:

     copyonwrite机制:

           当进行资源写入时,系统生成资源副本进行修改。保证写入原子性。写入加锁

 

hashset:

       底层实现:hashmap K+new Object

 

copyonwriteArraySet:

       底层:copyonwritearraylist

        添加元素前判断数据是否存在

concurrentskiplistset:

        底层:concurrentSkiplistMap

 

Queue:

    add:队列已满抛异常

    remove(element):队列为空抛异常

    offer:添加失败返回false

    poll(peek):如果没有返回null

    put:如果队列满了就阻塞

    take: 队列为空则阻塞

ArrayBlockingQueue:

     循环数组: putindex takeindex

LinkedBlockingQueue:

     底层 链表。因为链表 所以可以不指定长度(无穷长)

ConcurrentLinkedQueue:

     没有阻塞方法put、take,cas操作实现高并发+线程安全

      容量无限

 

SynchronoursQueue:

     容量为0  同步队列 有进有出~    常见cachedExecutor

 

PriorityBlockingQueue:

    优先级队列  不是先进先出。 可以传入比较器 定义优先级规则

   

以上是关于134 并发容器类~list set queue的主要内容,如果未能解决你的问题,请参考以下文章

Java并发编程:同步容器

提升--12---并发容器历史

多线程5-同步容器和并发容器

Java并发编程:同步容器

[Java并发编程] 并发容器框架的简单介绍

高并发下的Java数据结构(List,Set,Map,Queue)