Synchronized和Lock的区别

简介: Synchronized和Lock的区别

在分布式开发中,锁是控制线程安全的重要方式。Java提供了两种锁机制synchronized 和 Lock。

1、特性区别

Synchronized是Java内置的线程同步关键字;

Lock是JUC包下面的一个接口,它有很多实现类,比如ReentrantLock就是它的一个实现类;

2、用法区别

synchronized可以写在需要同步的对象、方法或者是特定代的码块中。主要有两种写法,比如:

//控制方法
public synchronized void sync(){
}

代码块

Object lock = new Object();
//控制代码块
public void sync(){
synchronized(lock){
}}

用这种方式来控制锁的生命周期。而Lock控制锁的粒度是通过lock() 和 unlock() 方法来实现的,以ReentrantLock为例,来看这样一段代码:

Lock lock = new ReentrantLock();
public void sync(){
lock.lock();   //添加锁
//TODO线程安全的代码
lock.unlock(); //释放锁
}

这种方式,是可以保证lock()方法和unlock()方法之间的代码是线程安全的。而锁的作用域,取决于Lock实例的生命周期。

Lock比synchronized在使用上相对来说要更加灵活一些。Lock可以自主地去决定什么时候加锁,什么时候释放锁。只需要调用lock()和unlock()这两个方法就可以了。需要注意的是,为了避免死锁,一般我们unlock()方法写在finally块中。

另外,Lock还提供了非阻塞的竞争锁的方法叫trylock(),这个方法可以通过返回true或者fasle来告诉当前线程是否已经有其他线程正在使用锁。

而synchronized是关键字,无法去扩展实现非阻塞竞争锁的方法。另外,synchronized只有代码块执行结束或者代码出现异常的时候才会释放锁,因此,它对锁的释放是被动的。

3、性能区别

synchronized和Lock在性能上差别不大。在实现上有一些区别,

synchronized 采用的是悲观锁机制,synchronized 是托管给 JVM 执行的。在JDK1.6以后采用了偏向锁、轻量级锁、重量级锁及锁升级的方式进行优化。

而 Lock 用的是乐观锁机制。控制锁的代码由用于自定义,也采用CAS自旋锁进行了优化。

4、用途区别

二者在一般情况下没有什么区别,但是在非常复杂的同步应用中,建议使用Lock。

因为synchronized只提供了非公平锁的实现,而Lock提供了公平锁和非公平锁的机制。

公平锁是指线程竞争锁资源的时候,如果已经有其他线程正在排队或者等待锁释放,那么当前竞争锁的线程是无法去插队的。

而非公平锁就是不管是否线程在排队等待锁,它都会去尝试竞争一次锁。


目录
相关文章
|
5月前
|
人工智能 Java 开发者
【Spring】原理解析:Spring Boot 自动配置
Spring Boot通过“约定优于配置”的设计理念,自动检测项目依赖并根据这些依赖自动装配相应的Bean,从而解放开发者从繁琐的配置工作中解脱出来,专注于业务逻辑实现。
1956 0
|
Arthas 测试技术
【面试题精讲】JVM-类加载器-使用Arthas查看类加载器
【面试题精讲】JVM-类加载器-使用Arthas查看类加载器
【面试题精讲】JVM-类加载器-使用Arthas查看类加载器
|
2月前
|
人工智能 自然语言处理 监控
盘点 2025 电商自动化利器:Agent 产品实力排行,降本增效不空谈
电商进入存量竞争时代,获客难、运营重、跨境壁垒高。智能Agent成破局关键,尤以融合大模型与自动化的“数字员工”为代表。实在Agent凭RPA进化基因与“一句话生成流程”能力,实现跨系统协同、全场景覆盖;瓴羊Quick Service擅全渠道客服,扛大促峰值;探迹·探域智能体轻量零配置,中小商家首选。选型需按规模、场景匹配,聚焦易用性、兼容性与数据安全,让AI真正赋能增长。
422 8
|
消息中间件 存储 监控
MQ线上大规模消息堆积问题处理及使用场景详解
【11月更文挑战第21天】在如今的高并发互联网应用中,消息队列(Message Queue,简称MQ)扮演着至关重要的角色
932 1
【多线程面试题十三】、说一说synchronized与Lock的区别
这篇文章讨论了Java中`synchronized`和`Lock`接口在多线程编程中的区别,包括它们在实现、使用、锁的释放、超时设置、锁状态查询以及锁的属性等方面的不同点。
|
存储 Kubernetes C++
【专栏】Kubernetes VS Docker Swarm了解两者特点,助力选取合适容器编排工具
【4月更文挑战第27天】对比Kubernetes和Docker Swarm:K8s在可扩展性和自动化方面出色,有强大社区支持;Swarm以简易用著称,适合初学者。选择取决于项目需求、团队技能和预期收益。高度复杂项目推荐Kubernetes,快速上手小项目则选Docker Swarm。了解两者特点,助力选取合适容器编排工具。
485 1
|
11月前
|
JavaScript Java Docker
干货含源码!如何用Java后端操作Docker(命令行篇)
只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
安全 Java 测试技术
code review 正确方式
code review 正确方式
380 1
|
Java 测试技术 API
Java 新手入门:Java单元测试利器,Mock详解
Java 新手入门:Java单元测试利器,Mock详解
1012 1
|
传感器 编解码 监控
线程池有哪些拒绝策略?
本文介绍了Java线程池的四种拒绝策略:AbortPolicy(默认策略,抛出异常)、CallerRunsPolicy(调用者运行任务)、DiscardPolicy(丢弃任务,不抛异常)和DiscardOldestPolicy(丢弃最旧任务,尝试提交当前任务)。每种策略都有其适用的业务场景,并通过代码示例进行了说明。选择合适的策略取决于具体的应用需求和对任务处理的优先级。
1188 0