Java并发编程类学习四(线程安全的类)

同步容器类

Vector和Hashtable是重量级线程安全的,不建议使用。另外还可以用Collections.synchronizedXXXX工厂方法同步类。

并发容器

ConcurrentHashMap、ConcurrentLinkedQueue、ConcurrentLinkedDeque、ConcurrentSkipListSet和CopyOnWriteArrayList等等。他们都是线程安全的。

阻塞容器

  • ArrayBlockingQueue:基于数组实现的一个阻塞队列,在创建ArrayBlockingQueue对象时必须制定容量大小。并且可以指定公平性与非公平性,默认情况下为非公平的,即不保证等待时间最长的队列最优先能够访问队列。
  • LinkedBlockingQueue和LinkedBlockingDeque:基于链表实现的一个阻塞队列,在创建LinkedBlockingQueue对象时如果不指定容量大小,则默认大小为Integer.MAX_VALUE。
  • PriorityBlockingQueue:以上2种队列都是先进先出队列,而PriorityBlockingQueue却不是,它会按照元素的优先级对元素进行排序,按照优先级顺序出队,每次出队的元素都是优先级最高的元素。注意,此阻塞队列为无界阻塞队列,即容量没有上限(通过源码就可以知道,它没有容器满的信号标志),前面2种都是有界队列。
  • DelayQueue:基于PriorityQueue,一种延时阻塞队列,DelayQueue中的元素只有当其指定的延迟时间到了,才能够从队列中获取到该元素。DelayQueue也是一个无界队列,因此往队列中插入数据的操作(生产者)永远不会被阻塞,而只有获取数据的操作(消费者)才会被阻塞。

原子类

  • AtomicBoolean – 原子布尔
  • AtomicInteger – 原子整型
  • AtomicIntegerArray – 原子整型数组
  • AtomicLong – 原子长整型
  • AtomicLongArray – 原子长整型数组
  • AtomicReference – 原子引用
  • AtomicReferenceArray – 原子引用数组
  • AtomicMarkableReference – 原子标记引用
  • AtomicStampedReference – 原子戳记引用
  • AtomicIntegerFieldUpdater – 用来包裹对整形 volatile 域的原子操作
  • AtomicLongFieldUpdater – 用来包裹对长整型 volatile 域的原子操作
  • AtomicReferenceFieldUpdater – 用来包裹对对象 volatile 域的原子操作

你可能感兴趣的:(java,并发编程)