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接口,需要自己设置队列中的等待时间,到达时间之后才可取出
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值