news 2026/6/5 18:47:24

Java中的锁对象详解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Java中的锁对象详解

锁是什么?

1.对于实例方法(非static)

publicclassDemo{// 实例方法上的synchronizedpublicsynchronizedvoidmethodA(){methodB();// 调用另一个synchronized方法}publicsynchronizedvoidmethodB(){// ...}}

锁对象 = 当前实例对象(this)

示例:

Demodemo1=newDemo();Demodemo2=newDemo();// demo1.methodA() 和 demo1.methodB() 使用 demo1 作为锁// demo2.methodA() 和 demo2.methodB() 使用 demo2 作为锁// demo1和demo2之间互不影响,因为它们使用不同的锁对象

2.对于静态方法(static)

publicclassDemo{// 静态方法上的synchronizedpublicstaticsynchronizedvoidstaticMethodA(){staticMethodB();// 调用另一个静态synchronized方法}publicstaticsynchronizedvoidstaticMethodB(){// ...}}

锁对象 = 类的Class对象(Demo.class)

3.对于同步代码块

publicclassDemo{privatefinalObjectlock=newObject();publicvoidmethodA(){synchronized(lock){// 使用lock对象作为锁// ...}}publicvoidmethodB(){synchronized(lock){// 使用同一个lock对象作为锁// ...}}}

锁对象 = synchronized括号里指定的对象

验证示例

publicclassLockIdentityDemo{// 实例同步方法publicsynchronizedvoidinstanceMethodA(){System.out.println("methodA锁对象: "+this);instanceMethodB();}publicsynchronizedvoidinstanceMethodB(){System.out.println("methodB锁对象: "+this);}// 静态同步方法publicstaticsynchronizedvoidstaticMethodA(){System.out.println("staticMethodA锁对象: "+LockIdentityDemo.class);staticMethodB();}publicstaticsynchronizedvoidstaticMethodB(){System.out.println("staticMethodB锁对象: "+LockIdentityDemo.class);}publicstaticvoidmain(String[]args){LockIdentityDemodemo1=newLockIdentityDemo();LockIdentityDemodemo2=newLockIdentityDemo();System.out.println("=== 测试实例方法 ===");System.out.println("demo1对象: "+demo1);System.out.println("demo2对象: "+demo2);newThread(()->demo1.instanceMethodA()).start();newThread(()->demo2.instanceMethodA()).start();System.out.println("\n=== 测试静态方法 ===");newThread(()->LockIdentityDemo.staticMethodA()).start();}}

锁的作用范围表格

同步方式锁对象影响范围示例
synchronized 实例方法当前对象(this)该实例的所有synchronized实例方法demo.methodA()会阻塞demo.methodB()
synchronized static方法类的Class对象该类的所有synchronized static方法Demo.staticMethodA()会阻塞Demo.staticMethodB()
synchronized(this)当前对象(this)该实例的所有同步块与实例方法互斥
synchronized(Class)类的Class对象该类的所有相关同步与static方法互斥
synchronized(obj)指定对象obj所有同步该对象的代码自定义锁对象

重要规则

  1. 同一个锁对象才会产生互斥

    Demoobj1=newDemo();Demoobj2=newDemo();// 这两个调用不会互相阻塞,因为锁对象不同obj1.syncMethod();// 锁是obj1obj2.syncMethod();// 锁是obj2
  2. 不同类型的方法使用不同的锁

    publicclassDemo{publicsynchronizedvoidinstanceMethod(){}// 锁:thispublicstaticsynchronizedvoidstaticMethod(){}// 锁:Demo.classpublicvoidtest(){// 这两个方法不会互相阻塞!instanceMethod();// 锁thisstaticMethod();// 锁Demo.class}}
  3. 锁的粒度控制

    publicclassBankAccount{privatefinalObjectreadLock=newObject();privatefinalObjectwriteLock=newObject();publicvoidread(){synchronized(readLock){// 读锁// 多个线程可以同时读}}publicvoidwrite(){synchronized(writeLock){// 写锁// 写操作互斥}}}

实际应用建议

  1. 明确指定锁对象:使用同步代码块比同步方法更灵活
  2. 减小锁粒度:使用不同的锁保护不同的资源
  3. 避免锁混淆:注意实例锁和类锁的区别
  4. 文档说明:在代码中注释说明使用的锁对象

理解"锁是什么对象"是解决Java并发问题和避免死锁的关键!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 9:24:50

高效管理临时文件:自动化清理方案全解析

临时文件自动化管理方案技术文章大纲背景与需求分析临时文件的定义及其在系统中的常见来源(如缓存、日志、下载目录等)临时文件管理不善的潜在问题(磁盘空间占用、性能下降、安全隐患)自动化管理的核心目标(高效清理、…

作者头像 李华
网站建设 2026/5/30 8:26:58

铅冶炼含铊污酸处理技术:Tulsimer树脂助力污泥减量与稳定达标

在环保监管日趋严格的背景下,铅冶炼行业含铊污酸处理已成为制约企业合规运营的核心难题。此类烟气净化废水占冶炼总废水量的20%-30%,受原料含铊特性及稀酸循环使用影响,水体中总铊浓度呈持续攀升态势,给处理工艺带来极大挑战。铊作…

作者头像 李华
网站建设 2026/6/4 15:17:24

ZGLanguage 解析SQL数据血缘 之 提取子查询语句中的源表名

# 假设存在 子查询SQL代码 如下:SELECT CL.OBJECTNO, PP.PAYDATEFROM NYBDP.O_SS_CL_LOAN_ACCT_STATIS CLLEFT JOIN (SELECT AL.PAYDATE, BC.BUSS_NOFROM O_CWWS_ACCT_LOAN ALINNER JOIN NYBDP.O_CWWS_BUSINESS_DUEBILL BDON 11LEFT JOIN O_CWWS_BUSINESS_CONTRACT …

作者头像 李华
网站建设 2026/5/27 12:31:35

Katalon StudioAssist Ask模式:工作区内的AI测试助手

在自动化测试领域,高效地编写脚本、理解复杂概念或排查问题是日常工作的一部分。传统上,这需要开发者翻阅大量文档、在社区提问或反复调试。Katalon Studio 推出的 StudioAssist Ask 模式,就像一位始终在线的专家伙伴,将人工智能的…

作者头像 李华
网站建设 2026/6/3 5:22:15

都在做「WAN优化」,南凌科技的方案究竟有何不同?

在企业数字化转型过程中,WAN优化已成为常见需求。面对市场上众多看似雷同的“降本增效”方案,IT管理者往往难以抉择:究竟哪家能真正解决问题?事实上,许多传统WAN优化方案仅从单点入手,例如数据压缩或协议加…

作者头像 李华
网站建设 2026/6/4 23:29:26

php+nginx在cookie中设置了HttpOnly属性

该网站cookie没有设置HttpOnly标志。如果您在cookie中设置了HttpOnly属性,那么通过js脚本将无法读取到cookie信息,是防止XSS攻击的一种安全措施。 攻击者可以通过document对象获取Cookie,进行xss等攻击。 需要在网站服务器代码上修改,设置办法举例:heade…

作者头像 李华