本文较为详细的分析了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程序设计有所帮助。
如对本文有疑问, 点击进行留言回复!!
如何在IDEA中对 hashCode()和 equals() 利用快捷键快速进行方法重写
springboot集成普罗米修斯(Prometheus)的方法
Tomcat启动springboot项目war包报错:启动子级时出错的问题
如何利用Spring的@Import扩展点与spring进行无缝整合
网友评论