栏目:线程与并发 作者:admin 日期:2017-04-22 评论:0 点击: 1,933 次
synchronized的本质是给对象上锁,对象包括实例对象,也包括类对象。常见的加锁方式有下面几种写法:
(1)在非static方法上加synchronized,例如:public void synchronized test() { } ,则相当于:
public void test()
{
synchronized(this){}
}
(2)在static方法上添加synchronized,相当于锁住的类对象,例如:synchronized(Test.class){}
JVM规范规定JVM基于进入和退出Monitor对象来实现方法同步和代码块同步,但两者的实现细节不一样。代码块同步是使用monitorenter和monitorexit指令实现,而方法同步是使用另外一种方式实现的,细节在JVM规范里并没有详细说明,但是方法的同步同样可以使用这两个指令来实现。monitorenter指令是在编译后插入到同步代码块的开始位置,而monitorexit是插入到方法结束处和异常处, JVM要保证每个monitorenter必须有对应的monitorexit与之配对。任何对象都有一个 monitor 与之关联,当且一个monitor 被持有后,它将处于锁定状态。线程执行到 monitorenter 指令时,将会尝试获取对象所对应的 monitor 的所有权,即尝试获得对象的锁。
理论上,每个对象都可以做为锁,可以成为锁对象。每个锁对象都有两个队列,一个是就绪队列,一个是阻塞队列,就绪队列存储了将要获得锁的线程,阻塞队列存储了被阻塞的线程,当一个被线程被唤醒 (notify)后,才会进入到就绪队列,等待CPU的调度。
------====== 本站公告 ======------
金丝燕网,一个严谨的网站!