synchronize、ReentrantLock区别
共同点:
都是可重入锁,都可以在一个锁中调用另一个被同一个锁锁定的方法。
区别:
synchronize锁
1、synchronize是java的关键字,是java语言内置的特性,是在JVM层面上实现的
2、无论是读操作还是写操作还是混合操作都需要其中一个线程执行完毕之后另一个线程才能执行。这也是它的缺点,多线程情况下读操作不会造成数据的版本问题,以为没有修改。如果此时每个读线程都排队等待会造成很大的资源浪费,完全可以并行执行读操作。
3、如果发生异常synchronize会自动释放锁。
4、线程执行完代码后synchronize会自动释放锁,不用手动编写释放锁的代码。
5、使用synchronize时等待的线程会一直等待下去,不能够相应中断
6、synchronized默认就是非公平锁,而且没有内置公平锁的实现。
7、synchronize无法知道有没有成功获取锁。
ReentrantLock锁
1、Lock锁是java的一个接口,ReentrantLock实现了Lock接口
2、无论是读操作还是写操作还是混合操作都需要其中一个线程执行完毕之后另一个线程才能执行。这也是它的缺点,多线程情况下读操作不会造成数据的版本问题,以为没有修改。如果此时每个读线程都排队等待会造成很大的资源浪费,完全可以并行执行读操作。但是可以使用读写锁ReentrantReadWriteLock来解决这个问题。读写锁对读操可以是并行的。但是当有写操作、读写同时操作时则是串行的。
3、发生异常也不会自动释放锁,需要手动在finally代码块中释放。
4、代码执行完ReentrantLock不会自动释放锁,需要手动在finally代码块中释放。
5、ReentrantLock可以响应中断,例如T1、T2两个线程,T1先获得锁,此时T2可以被打断以放弃锁的等待,进而执行其他任务。
6、ReentrantLock的构造方法可以接受false实现非公平锁或者true来实现公平锁。默认是非公平锁。公平锁:ReentrantLock lock =
new
ReentrantLock(
true
);
7、ReentrantLock的lock.tryLock()可以尝试获取锁,并返回是否获取成功的标识。