Java中同步与并发用法分析

这篇文章主要介绍了Java中同步与并发用法,较为详细的分析了java同步与并发所涉及的相关类与使用技巧,需要的朋友可以参考下

本文较为详细的分析了Java中同步与并发的用法分享给大家供大家参考。具体分析如下:

1.同步容器类包括两部分:vector和hashtable

另一类是同步包装类,由Collections.synchronizedXXX创建。同步容器对容器的所有状态进行串行访问,从而实现线程安全。

它们存在如下问题:

a) 对于符合操作,需要额外的锁保护。比如迭代,缺少则添加等条件运算。

b) toString,hashCode,equals都会间接的调用迭代,都需要注意并发。

 

2.java5.0中的并发容器。

ConcurrentHashMap可以替代同步Map实现。

当主要为读操作时,copyOnWriteArrayList是List的同步实现。

同时,增加了Queue和BlockingQueue:ConcurentLinkedQueue:FIFO队列。

PriorityQueue:非并发的优先级顺序队列。

BlockingQueue则增加了可阻塞的插入和获取

a) ConcurentHashMap:不是使用一个公共锁,而是分离锁。任意数量的读线程可以并发访问map,读者和写者也可以并发访问Map,并且有限数量的写还可以并发修改Map。但是,size和isEmpty语言被弱化,是估算值。

b) copyOnWriteArrayList:迭代器保留一个底层基础数组引用,改引用不会修改

 

3.Synchronizer

a) 闭锁(CountDownLatch)。构造函数参数为n,通过countDown,n为0后,所有await的线程继续执行。

b) FutureTask:计算由Callable实现,可以携带结果的Runnable。包括:等待,运行和完成。

c) Semaphore:控制能够同时访问的活动数量

d) CyclicBarrier:类似于闭锁。闭锁等待的是事件,关卡等待的是其他线程。初始n,Runnable r,n个线程都await(),当n个线程都执行完成后到达关卡时,r执行,关卡重置,n个线程继续。

希望本文所述对大家的java程序设计有所帮助。

相关文章

HashMap是Java中最常用的集合类框架,也是Java语言中非常典型...
在EffectiveJava中的第 36条中建议 用 EnumSet 替代位字段,...
介绍 注解是JDK1.5版本开始引入的一个特性,用于对代码进行说...
介绍 LinkedList同时实现了List接口和Deque接口,也就是说它...
介绍 TreeSet和TreeMap在Java里有着相同的实现,前者仅仅是对...
HashMap为什么线程不安全 put的不安全 由于多线程对HashMap进...