Java高并发容器选择

1. 对于Map/Set的使用

(1)非并发

  • HashMap
  • TreeMap
  • LinkHashedMap

(2)不复杂的、并发量低的并发

  • HashTable
  • Collections.sychronizedXXX

(3)复杂的、并发量高的并发

  • ConcurrentHashMap //不需要排序的
  • ConcurrentSkipListMap //需要排序的

2.队列的使用

(1)非并发

  • ArrayList
  • LinkedList

(2)不复杂的、并发量低的并发

  • Collections.sychronizedXXX
  • Vector

(3)复杂的、并发量高的并发

  • ConcurrentLinkedQueue
  • CopyOnWriteList
    • 写时复制一份,写进新的这份中,如果与此同时发生了读,就读之前那份,写的非常少读的非常的多时用
  • BlockingQueue
    • LinkedBlockingQueue(无界队列
    • ArrayBlockingQueue(有界队列
    • TransferQueue(阻塞执行
    • SynchronousQueue(特殊的TransferQueue,容量0,put约等于TransferQueue的transfer
  • DelayQueue
    • 队列中的元素要实现Delayed接口,Delayed接口继承了Comparable接口,需要自己设置队列中的等待时间,到达时间之后才可取出
发布了52 篇原创文章 · 获赞 9 · 访问量 6191

猜你喜欢

转载自blog.csdn.net/weixin_43553694/article/details/104496266