内置锁机制:synchronized,
一个synchronized快有两部分 ,所对象的引用,以及锁保护的代码块,至于synchronized方法的锁,就是方法所在的对象本身
(静态synchronized方法从Class对象上获取锁)
synchronized(lock){
//访问或修改被锁保护的共享状态
}
称为内部锁(intrinsic locks)或监视器锁(monitor locks)
执行线程进入synchronized快之前自动获得锁,
内部锁在Java中扮演了互斥锁(mutext exclusion lock)角色,意味着只有一个线程可以拥有锁
但是禁止了多个用户同时使用一个方法,导致无法令人无法接受的响应性,而这是一个性能问题而非线程安全问题
重进入(Reentrancy)
重进入意味着锁的请求是基于“每线程(per-thread)”,而不是基于“每调用(per-invocation)”,
重进入的实现是通过唯每一个锁关联关联一个计数(acquisition)和一个占有它的线程。