多线程系列(二)---多个线程多个锁

多个线程多个锁:多个线程,每个线程都可以拿到自己指定的锁,分别获得锁之后,执行synchronized方法体内容。

关键字synchronized取得的锁都是对象锁,而不是把一段代码(方法)当做锁,哪个线程先执行synchronized关键字的方法,那个线程就持有该方法所属对象的锁(Lock),两个对象,线程获得的就是两个不同的锁,他们互不影响。

有一种特殊情况则是相同的锁,即在静态方法上加synchronized关键字,表示锁定class类,类一级别的锁(独占.class类)

多线程系列(二)---多个线程多个锁_第1张图片

从打印的结果我们可以看出,输出的结果有问题。因为我们在printNum方法上加了synchronized锁,那么应该是线程m1输出tag b,set count over!、taga,count=100之后才会打印b的信息。为什么会造成这样的结果呢???

原来我们声明了t1和t2两个对象,在m1线程中调取t1对象,拥有的是t1对象的锁,而m2线程中调取t2对象,拥有的是t2对象的锁。关键字synchronized取得的锁都是对象锁,这样他们就互不影响,t1和t2的信息都保存在自己的线程栈中,对其他线程不可见,所有m1和m2并发执行。

如果在printNum方法上加上static关键字,,表示锁定class类。不管声明多少个MultiThread引用,printNum方法跟随类存放在堆上,线程间会共享资源,输出结果会等m1信息输出结束之后才会开始输出m2信息。

多线程系列(二)---多个线程多个锁_第2张图片

总结:

一个对象一把锁

在静态方法上synchronized代表的是类的锁


本人在码云上提交了关于阅读spring源码之后编写的一些基础模块的实现,https://git.oschina.net/73hulu/spring.git 望大家不吝给颗星star,谢谢大家

你可能感兴趣的:(java基础)