码迷,mamicode.com
首页 > 编程语言 > 详细

第一章 Java常用的并发类

时间:2016-01-08 13:21:17      阅读:183      评论:0      收藏:0      [点我收藏+]

标签:

注:本系列博客主要参考于《分布式Java应用:基础与实践》,林昊 著

1、常用的并发集合类

  • ConcurrentHashMap:线程安全的HashMap的实现
  • CopyOnWriteArrayList:线程安全且在读操作时无锁的ArrayList
  • CopyOnWriteArraySet:基于CopyOnWriteArrayList,不添加重复元素
  • ArrayBlockingQueue:基于数组、先进先出、线程安全,可实现指定时间的阻塞读写,并且容量可以限制
  • LinkedBlockingQueue:基于链表实现,读写各用一把锁,在高并发读写操作都多的情况下,性能优于ArrayBlockingQueue

2、原子类

  • AtomicInteger:线程安全的Integer,基于CAS(无阻塞,CPU原语),优于使用同步锁的Integer

3、线程池

  • ThreadPoolExecutor:一个高效的支持并发的线程池,可以很容易的讲一个实现了Runnable接口的任务放入线程池执行,但要用好这个线程池,必须合理配置corePoolSize、最大线程数、任务缓冲队列,以及队列满了+线程池满时的回绝策略,一般而言对于这些参数的配置,需考虑两类需求:高性能和缓冲执行
  • Executor:提供了一些方便的创建ThreadPoolExecutor的方法。
  • FutureTask:可用于异步获取执行结果或取消执行任务的场景,基于CAS,避免锁的使用

4、锁

  • ReentrantLock:与synchronized效果一致,但是效率更高,需要手工释放锁,基于AbstractQueueSynchronizer
  • ReentrantReadWriteLock:与ReentrantLock没有关系,采用两把锁,用于读多写少的情形

 

注:在本系列的博客中,对以上的类会着重从以下几个方面去记录:

  • 用法
  • 源码解读
  • 使用场景
  • 一些必要的比较

第一章 Java常用的并发类

标签:

原文地址:http://www.cnblogs.com/java-zhao/p/5112791.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!