Synchronized中的对象锁与类锁的区别

本文深入探讨了Java中synchronized关键字的使用,详细解释了对象锁和类锁的概念及其应用。通过具体的代码示例,展示了如何使用synchronized创建线程安全的代码块,以及不同锁类型在多线程环境下的行为差异。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

将必须同步的代码使用synchronized代码块(对象/类锁)

对象锁

对象锁也叫方法锁,是针对一个对象实例的,它只在该对象的某个内存位置声明一个标识该对象是否拥有锁,所有它只会锁住当前的对象,而并不会对其他对象实例的锁产生任何影响,不同对象访问同一个被synchronized修饰的方法的时候不会阻塞

OutMe.java
public class OutMe {
// 这也是对象锁
//	synchronized void sync_out_Some() {
//		try {
//            System.out.println(Thread.currentThread().getName());
//            Thread.sleep(4000);
//        } catch (InterruptedException e) {
//            e.printStackTrace();
//        }
//	}
// 这是对象锁:减小锁粒度,第二种形式就比较好
	void sync_out_Some() {
		synchronized (this) {
			try {
	            System.out.println(Thread.currentThread().getName());
	            Thread.sleep(4000);
	        } catch (InterruptedException e) {
	            e.printStackTrace();
	        }
		}
	}
	void out_some() {
		System.out.println(Thread.currentThread().getName());
	}

}


package test;

Test2.java
package test;


public class Test2 {
	public static void main(String[] args) {
		OutMe outMe=new OutMe();
		OutMe outMe2=new OutMe();
		Thread out1Thread=new Thread(new Runnable() {
			public void run() {
				outMe.sync_out_Some();
			}
		},"out1Thread_1");
		/**对象锁:
		 *  注销 注释(1)运行结果: out1Thread_1输出后 4秒以后 
		 * 输出 out2Thread_1 最后还要执行sleep() 4秒后 程序结束:同一对象的同步;
		 * 
		 *  注销 注释(2)运行结果:同时输出out2Thread_1、out1Thread_1:
		 * 对象锁只针对同一对象,不同对象不起作用
		 * 
		 *  注销 注释(3)运行结果:同时输出out2Thread_1、out1Thread_1:
		 * out_some没有加synchronized修饰
		 */
		Thread out2Thread=new Thread(new Runnable() {
			public void run() {
//				outMe.sync_out_Some(); (1)
//				outMe2.sync_out_Some(); (2)
//				outMe.out_some(); (3)
			}
		},"out2Thread_1");
		out1Thread.start();
		out2Thread.start();
	}
}

类锁

不管多少个对象,多少个对象,共用一把多,且只有一把,不管怎么调用,都会同步

OutMe.java
package test;

public class OutMe {
//  这也是类锁:就是在void 上加le static 
//	synchronized static void sync_out_Some() {
//		try {
//            System.out.println(Thread.currentThread().getName());
//            Thread.sleep(4000);
//        } catch (InterruptedException e) {
//            e.printStackTrace();
//        }
//	}
	void sync_out_Some() {
	// 就这里不同:对象锁括号里面的是this
	// 类锁 里面也可以为 this.getClass() 或 类名.class :获得的都是该类型OutMe的类型类
	// 里面有OutMe的所有信息:直接父类、全称、实现的所有接口等等
		synchronized (OutMe.class) {
			try {
	            System.out.println(Thread.currentThread().getName());
	            Thread.sleep(4000);
	        } catch (InterruptedException e) {
	            e.printStackTrace();
	        }
		}
	}
	void out_some() {
		System.out.println(Thread.currentThread().getName());
	}
}

/**
		 * 类锁
		 * 注销 注释(1)或 (2):
		 * 都是 out1Thread_1输出后 4秒以后 输出 out2Thread_1:他们都是同一个类
		 */

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值