面试官问:说一下lock和Synchronized有什么区别?

导读:本篇文章讲解 面试官问:说一下lock和Synchronized有什么区别?,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

思路

对于这个问题,我们完全可以通过结构化的方式去回答,从三个点切入,第一个是从功能层面,第二个是从特性层面,第三个是从性能层面,基于这三个点,再去展开每一个点的细节。

回答

一、从功能角度来看

Lock 和 Synchronized 都是 Java 里面用来解决线程安全问题的工具。

 

二、从特性来看

Synchronized 是 Java 中的同步关键字,Lock 是 J.U.C 包里面提供的一个接口,这个接口有很多实现类,其中就包括 ReentrantLock 重入锁。其次,Synchronized 可以通过两种方式来控制锁的粒度,如下所示

//修饰在方法层面
public synchronized void sync(){
}
Object lock = new Object();

//修饰在代码块
public void sync(){
    synchronized(lock){
    }
}

一种是把 synchronized 关键字修饰在方法层面,另一种是修饰在代码块上,并且我们可以通过 Synchronized 加锁对象的声明周期来控制锁的作用范围,比如锁对象是静态对象或者类对象,那么这个锁就是全局锁。

如果锁对象是普通实例对象,那这个锁的范围取决于这个实例的声明周期。

Lock lock = new ReentrantLock();

public void sync(){
    lock.lock();//竞争锁
    //TODO 线程安全的代码
    lock.unlock();//释放锁
}

如上面代码所示,Lock 锁的粒度是通过它里面提供的 lock()和 unlock()方法决定的,包裹在这两个方法之间的代码能够保证线程安全性。而锁的作用域取决于 Lock 实例的生命周期。

Lock 比 Synchronized 的灵活性更高,Lock 可以自主决定什么时候加锁,什么时候释放锁,只需要调用 lock()和 unlock()这两个方法就行,同时 Lock 还提供了非阻塞的竞争锁方法 tryLock()方法,这个方法通过返回 true/false 来告诉当前线程是否已经有其他线程正在使用锁。

而Synchronized 由于是关键字,所以它无法实现非阻塞竞争锁的方法,另外,Synchronized 锁的释放是被动的,就是说当 Synchronized 同步代码块执行完以后或者代码出现异常时才会释放。

Lock 提供了公平锁和非公平锁的机制,公平锁是指线程竞争锁资源时,如果已经有其他线程正在排队等待锁释放,那么当前竞争锁资源的线程无法插队。而非公平锁,就是不管是否有线程在排队等待锁,它都会尝试去竞争一次锁。而Synchronized 只提供了一种非公平锁的实现。

三、从性能方面来看

Synchronized 和 Lock 在性能方面相差不大,在实现上会有一些区别,Synchronized 引入了偏向锁、轻量级锁、重量级锁以及锁升级的方式来优化加锁的性能,而 Lock 中则用到了自旋锁的方式来实现性能优化。

 

以上就是我对于这个问题的理解,如果感觉对你有帮助的话点个小赞,同时也欢迎各位大佬指点~

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/81339.html

(0)
小半的头像小半

相关推荐

极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!