Java中Locks使用方法及详细解析是怎样的?
- 内容介绍
- 文章标签
- 相关推荐
本文共计1772个文字,预计阅读时间需要8分钟。
在先前文章中,我们提到Java中实现同步的一种方式是利用`synchronized`块。自Java 5起,引入了Locks,提供了更灵活的同步控制。本文将深入讲解Lock的使用及其与`synchronized`块的区别。
之前文章中我们讲到,java中实现同步的方式是使用synchronized block。在java 5中,Locks被引入了,来提供更加灵活的同步控制。
本文将会深入的讲解Lock的使用。
Lock和Synchronized Block的区别
我们在之前的Synchronized Block的文章中讲到了使用Synchronized来实现java的同步。既然Synchronized Block那么好用,为什么会引入新的Lock呢?
主要有下面几点区别:
- synchronized block只能写在一个方法里面,而Lock的lock()和unlock()可以分别在不同的方法里面。
- synchronized block 不支持公平锁,一旦锁被释放,任何线程都有机会获取被释放的锁。而使用 Lock APIs则可以支持公平锁。从而让等待时间最长的线程有限执行。
- 使用synchronized block,如果线程拿不到锁,将会被Blocked。
本文共计1772个文字,预计阅读时间需要8分钟。
在先前文章中,我们提到Java中实现同步的一种方式是利用`synchronized`块。自Java 5起,引入了Locks,提供了更灵活的同步控制。本文将深入讲解Lock的使用及其与`synchronized`块的区别。
之前文章中我们讲到,java中实现同步的方式是使用synchronized block。在java 5中,Locks被引入了,来提供更加灵活的同步控制。
本文将会深入的讲解Lock的使用。
Lock和Synchronized Block的区别
我们在之前的Synchronized Block的文章中讲到了使用Synchronized来实现java的同步。既然Synchronized Block那么好用,为什么会引入新的Lock呢?
主要有下面几点区别:
- synchronized block只能写在一个方法里面,而Lock的lock()和unlock()可以分别在不同的方法里面。
- synchronized block 不支持公平锁,一旦锁被释放,任何线程都有机会获取被释放的锁。而使用 Lock APIs则可以支持公平锁。从而让等待时间最长的线程有限执行。
- 使用synchronized block,如果线程拿不到锁,将会被Blocked。

