Java并发编程-ReentrantLock
代码示例:
Lock lock = new ReentrantLock(); lock.lock(); try { // update object state } finally { lock.unlock(); }
相比synchronized的优势
1.具有更好的并发性能,激烈争用情况下更佳的性能
2.添加了类似锁投票、定时锁等候和可中断锁等候的一些特性
源码分析:
点击lock方法,进入代码(NonfairSync):
final void lock() { //假设原始值是0 //那么获取锁之后,将值设为1 //并设置私有线程 if (compareAndSetState(0, 1)) setExclusiveOwnerThread(Thread.currentThread()); else //如果值不是期望值0,则说明被其它线程占用锁 //加锁失败,再次尝试加锁,失败则加入等待队列, //等待队列中会一直尝试加锁 //如果队列加锁不成功,那么进入中断 acquire(1); }
compareAndSetState方法运用了CAS
比较并替换的原理,此处是原子操作
作者:风过无痕-唐
出处:http://www.cnblogs.com/tangyanbo/
本文以学习、研究和分享为主,欢迎转载,但必须在文章页面明显位置给出原文连接。 如果文中有不妥或者错误的地方还望高手的你指出,以免误人子弟。如果觉得本文对你有所帮助不如【推荐】一下!如果你有更好的建议,不如留言一起讨论,共同进步! 再次感谢您耐心的读完本篇文章。欢迎加QQ讨论群
出处:http://www.cnblogs.com/tangyanbo/
本文以学习、研究和分享为主,欢迎转载,但必须在文章页面明显位置给出原文连接。 如果文中有不妥或者错误的地方还望高手的你指出,以免误人子弟。如果觉得本文对你有所帮助不如【推荐】一下!如果你有更好的建议,不如留言一起讨论,共同进步! 再次感谢您耐心的读完本篇文章。欢迎加QQ讨论群