Synchronized与Lock的区别

一、原始构成

synchronized是关键字属于JVM层面:

  monitorenter(底层是通过monitor对象来完成,其实wait/notify等方法也依赖于monitor对象,只有在同步块或方法中才能调用wait/notify等方法)

       monitorexit

Lock是具体类(java.util.concurrent.locks.Lock)是api层面的锁

二、使用方法

synchronized 不需要用户去手动释放锁,当synchronized代码执行完后系统会自动让线程释放对锁的占用

ReentrantLock则需要用户去手动释放锁,若没有主动释放锁,就有可能导致出现死锁现象,需要lock() 和 unlock() 方法配合try/finally语句块来完成

三、等待是否可中断

synchronized不可中断,除非抛出异常或者正常运行完成

ReenrantLock 可中断,1. 设置超时方法 tryLock(long timeout, TimeUnit unit)

            2. lockInterruptibly() 放代码块中,调用interrupt() 方法可中断

四、加锁是否公平

synchronized非公平锁

ReentrantLock两者都可以 ,默认非公平锁,构造方法可以传入boolean值,true为公平锁,false为非公平锁

五、锁绑定多个条件Condition

synchronized没有

ReentrantLock用来实现分组唤醒需要唤醒的线程们,可以精确唤醒,而不是像synchronized要么随机唤醒一个线程要么唤醒全部线程

posted @   没有你哪有我  阅读(80)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· DeepSeek在M芯片Mac上本地化部署
· 葡萄城 AI 搜索升级:DeepSeek 加持,客户体验更智能
点击右上角即可分享
微信分享提示