方法锁、对象锁和类锁区别

引言:结合synchronized进行分析。

synchronized用来处理多个线程同时访问同一个类的一个代码块、方法,甚至这个类。

(1)修饰代码块时,需要一个reference对象作为锁的对象。

(2)修饰方法时,默认是当前对线作为锁的对象。

(3)修饰类时,默认是当前类的Class对象作为锁的对象。

1、对象锁

当一个对象中有同步方法或者同步块,线程调用此对象进入该同步区域时,必须获得对象锁。如果此对象的对象锁被其他调用者占用,则进入阻塞队列,等待此锁被释放(同步块正常返回或者抛异常终止,由JVM自动释放对象锁)。
注意,方法锁也是一种对象锁。当一个线程访问一个带synchronized方法时,由于对象锁的存在,所有加synchronized的方法都不能被访问(前提是在多个线程调用的是同一个对象实例中的方法)。

对象锁有两种形式:

public class object {
	public synchronized void method(){
		System.out.println("我是对象锁也是方法锁");
	}
}
另外一种是:

public class object {
	public void method(){
		synchronized(this){
			System.out.println("我是对象锁");
		}
	}
}
2、类锁

一个class其中的静态方法和静态变量在内存中只会加载和初始化一份,所以,一旦一个静态的方法被申明为synchronized,此类的所有的实例化对象在调用该方法时,共用同一把锁,称之为类锁。

也是两种形式:

public class object {
	public static synchronized void method(){
		System.out.println("我是第一种类锁");
	}
}
第二种:

public class object {
	public void method(){
		synchronized (object.this) {
			System.out.println("我是第二种类锁");
		}
	}
}


  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值