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程序设计有所帮助。
相关文章
SpringBoot:JPA + AuditingEntityListener时区设置方式
这篇文章主要介绍了SpringBoot:JPA + AuditingEntityListener时区设置方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2021-12-12使用SpringAop动态获取mapper执行的SQL,并保存SQL到Log表中
这篇文章主要介绍了使用SpringAop动态获取mapper执行的SQL,并保存SQL到Log表中问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2023-03-03SpringBoot使用自定义注解+AOP+Redis实现接口限流的实例代码
这篇文章主要介绍了SpringBoot使用自定义注解+AOP+Redis实现接口限流,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2022-09-09DUBBO 日志过滤器,输出dubbo 接口调用入参、出参等信息(最新推荐)
这篇文章主要介绍了DUBBO 日志过滤器,输出dubbo 接口调用入参、出参等信息,首先自定义一个过滤器 DubboLoggerFilter.java,本文结合示例代码给大家讲解的非常详细,需要的朋友可以参考下2022-12-12Spring AOP如何整合redis(注解方式)实现缓存统一管理详解
这篇文章主要给大家介绍了关于Spring AOP如何整合redis(注解方式)实现缓存统一管理的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面随着小编来一起学习学习吧2018-08-08
最新评论