Java中lock锁的问题

Lock锁分为以下几种,可重入锁,非可重入锁,公平锁,非公平锁,读写锁。

可重入锁:synchronized和ReentrantLock锁均为可重入锁。当在一个获得了锁的方法中,调用另外一个需要获得锁的方法时,如果此时为可重入锁,则正常运行。如果为非可重入锁,则系统报错。

 

公平锁:一个线程在等待着另外线程释放资源时,当新加入另一个线程时,如果采取的是公平锁,则按照等待时间的先后顺序依次获得资源。假如采用的是非公平锁,则根据操作系统调度算法来进行分配。事实上,采用非公平锁,能够提高线程运行的效率。

 

读写锁:读写锁对系统资源的访问分为了读锁和写锁。如果分配的是读锁,则可以让多个线程同时对资源进行读取。

 

Lock是一个接口,它的实现类为ReentTrantLock。ReadWriteLock也是一个接口,实现类为ReentrantReadWriteLock。而synchronized是java的关键词。并且使用lock可以实现加锁,释放锁的操作。使用Lock必须主动去释放锁,而synchronized则不需要。

Lock可以让等待锁的线程响应中断,而synchronized则不行。使用synchronized的时候, 等待的线程会一直等待下去,不能够响应中断。

当有多个线程对资源进行读操作时(没有写操作),则可以使用Lock的ReadLock锁来让多个线程对资源进行同时读取,提高线程读操作的效率。

很多内容和原文字都是参考《java多线程编程》。大家可以看看,非常好的一本书。

原文地址:https://www.cnblogs.com/CloudStrife/p/7154078.html