在Java里synchronized锁住的是什么_Java对象锁与类锁原理说明

发布时间 - 2026-01-21 00:00:00    点击率:
synchronized 锁住的是 monitor 对象而非语法结构,具体锁目标取决于写法:this 锁实例、Class.class 或 static synchronized 锁类、自定义 final Object 锁更安全;字符串字面量和 Integer 缓存作锁易引发意外竞争。

synchronized 锁住的是 monitor 对象,不是方法、代码块或变量本身

这是最常被误解的一点:synchronized 并不“锁住方法”或“锁住代码”,它锁的是某个具体的 Java 对象(更准确地说,是该对象关联的 monitor)。JVM 通过对象头里的 Mark Word 记录锁状态,而这个 monitor 的归属对象,取决于你写法——thisClass.class 或任意一个 Object 实例。

常见错误现象:

  • 以为 public synchronized void methodA()public synchronized void methodB() 是“两个独立的锁”,其实它们共用同一个对象锁(this),线程 A 调用 methodA() 时,线程 B 就无法进入 methodB()
  • 在工具类中误用静态方法加 synchronized,结果所有调用方被串行化,性能骤降(比如一个全局 StringUtils.format() 被加了 static synchronized

对象锁 vs 类锁:看锁目标是不是 Class 对象

判断依据非常简单:锁对象是实例(this)还是类(XXX.class)。两者完全不冲突,可以同时被不同线程持有。

使用场景与对应写法:

  • 对象锁:保护单个对象的状态。适用于有状态的实例,如 BankAccount.withdraw()Counter.increment()
  • 类锁:保护类级别的共享资源,比如静态缓存、单例初始化、类加载时的元数据注册。典型写法:public static synchronized void init()synchronized (MyClass.class) { ... }

注意:类锁本质仍是对象锁,只是锁的对象是 MyClass.class 这个特殊的 Class 实例——而每个类在 JVM 中只有一份 Class 对象,所以它天然具有“全局唯一性”。

synchronized(this)、synchronized(XXX.class)、synchronized(staticObj) 的区别

这三种写法锁的目标完全不同,直接影响并发粒度和线程阻塞范围:

public class Counter {
    private int instanceCount = 0;
    private static int staticCount = 0;
    private static final Object STATIC_LOCK = new Object();

    // ✅ 锁 this:每个 Counter 实例互不影响
    public synchronized void incInstance() {
        instanceCount++;
    }

    // ✅ 锁 Counter.class:所有实例共享一把锁
    public static synchronized void incStatic() {
        staticCount++;
    }

    // ✅ 锁自定义静态对象:语义更清晰,且可避免反射/继承干扰
    public void incWithCustomLock() {
    

synchronized (STATIC_LOCK) { staticCount++; } } }

关键差异:

  • synchronized(this) → 锁当前实例,多个实例之间无竞争
  • synchronized(Counter.class) → 锁整个类,等价于 static synchronized 方法
  • synchronized(STATIC_LOCK) → 锁一个私有静态对象,推荐用于显式控制类级同步,避免意外暴露 Counter.class(比如被外部恶意 synchronized(Counter.class) 阻塞)

容易踩的坑:字符串字面量、Integer 缓存、锁泄漏

这些看似普通的对象,作为锁目标时极易引发隐蔽问题:

  • 字符串字面量作锁synchronized("key") —— 因为字符串常量池共享,不同模块可能无意中锁同一字符串,导致跨业务阻塞
  • Integer 等包装类作锁synchronized(Integer.valueOf(127)) 在 -128~127 范围内会命中缓存,等同于锁住一个全局共享对象,风险同上
  • 锁对象被重新赋值private Object lock = new Object(); ... lock = new Object(); → 原锁失效,后续同步块不再受控
  • 锁对象为 null → 运行时报 NullPointerException,且发生在 monitorenter 字节码处,堆栈不直观

建议统一用 private final Object lock = new Object(); 声明私有锁对象,避免任何隐式共享或生命周期问题。

真正难的从来不是“怎么加锁”,而是“锁谁、锁多大范围、会不会被别人意外拿到同一把锁”。monitor 机制本身很稳定,但锁目标选错,轻则性能瓶颈,重则死锁或功能紊乱——而这几乎全靠开发者对对象生命周期和共享边界的清醒判断。


# word  # java  # 字节  # 工具  #   # 区别  # 性能瓶颈  # 字符串常量  # 有锁 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 详解CentOS6.5 安装 MySQL5.1.71的方法  Laravel如何使用Spatie Media Library_Laravel图片上传管理与缩略图生成【步骤】  Laravel怎么实现模型属性转换Casting_Laravel自动将JSON字段转为数组【技巧】  Laravel怎么上传文件_Laravel图片上传及存储配置  Laravel如何使用Livewire构建动态组件?(入门代码)  极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?  惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?  Laravel怎么使用Collection集合方法_Laravel数组操作高级函数pluck与map【手册】  公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?  头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?  如何在万网ECS上快速搭建专属网站?  canvas 画布在主流浏览器中的尺寸限制详细介绍  JavaScript如何实现倒计时_时间函数如何精确控制  如何用PHP快速搭建高效网站?分步指南  如何在 Python 中将列表项按字母顺序编号(a.、b.、c. …)  Laravel如何清理系统缓存命令_Laravel清除路由配置及视图缓存的方法【总结】  C语言设计一个闪闪的圣诞树  HTML5打空格有哪些误区_新手常犯的空格使用错误【技巧】  Linux后台任务运行方法_nohup与&使用技巧【技巧】  Laravel如何记录日志_Laravel Logging系统配置与自定义日志通道  zabbix利用python脚本发送报警邮件的方法  如何在新浪SAE免费搭建个人博客?  独立制作一个网站多少钱,建立网站需要花多少钱?  html5如何设置样式_HTML5样式设置方法与CSS应用技巧【教程】  悟空识字怎么关闭自动续费_悟空识字取消会员自动扣费步骤  Bootstrap整体框架之JavaScript插件架构  uc浏览器二维码扫描入口_uc浏览器扫码功能使用地址  深圳网站制作平台,深圳市做网站好的公司有哪些?  使用C语言编写圣诞表白程序  Laravel集合Collection怎么用_Laravel集合常用函数详解  如何在阿里云完成域名注册与建站?  ,交易猫的商品怎么发布到网站上去?  Laravel如何实现一对一模型关联?(Eloquent示例)  Python进程池调度策略_任务分发说明【指导】  Linux系统命令中tree命令详解  html文件怎么打开证书错误_https协议的html打开提示不安全【指南】  JavaScript常见的五种数组去重的方式  Android okhttputils现在进度显示实例代码  在centOS 7安装mysql 5.7的详细教程  打造顶配客厅影院,这份100寸电视推荐名单请查收  千问怎样用提示词获取健康建议_千问健康类提示词注意事项【指南】  如何在 React 中条件性地遍历数组并渲染元素  奇安信“盘古石”团队突破 iOS 26.1 提权  Laravel怎么进行数据库事务处理_Laravel DB Facade事务操作确保数据一致性  jQuery validate插件功能与用法详解  微信h5制作网站有哪些,免费微信H5页面制作工具?  海南网站制作公司有哪些,海口网是哪家的?  如何快速搭建个人网站并优化SEO?  专业商城网站制作公司有哪些,pi商城官网是哪个?  Laravel Fortify是什么,和Jetstream有什么关系