JAVA 1.6锁状态转换


JVM 学不好 并发就学不好

面试问题
Object 有哪些方法
syn实现过程

wait notify 为什么要设计到Object上而不是接口?虽然可以 但是面向对象的思想 子类
object.wait thread.sleep 的区别?

wait释放锁 挂起

32位锁状态()
JDK1.6对锁优化 锁的状态从 无锁->偏向锁->轻量级锁->重量级锁(把所有等待线程放入)
JDK1.6之前 synchon 性能不高 ,之后优化 建议使用synchon
分段锁 curruntlok 用的就是syn
JVM源码



内核态到核心态 切换 耗费性能
轻量级锁 拿不到锁就阻塞式不合理的 所以用自适应的自旋锁 但是存在激烈的竞争 自旋次数多会浪费cpu,以短暂cpu负载 换取线程笨重的切换 多次自旋,浪费cpu 导致锁的膨胀 -> 重量级锁


多线程进入 能否抢到锁 抢不到进入队列
重量级锁 :Entry List 同步等待锁的队列

synchoronized是JVM的内置锁,而lock是Java代码实现的。lock是sync对的扩展,完全可以替代后者。lock可以重入,允许同一个线程连续多次获得同一把锁。其次,lock独有的功能有:

1、可以响应中断,sync要么获得锁执行,要么保持等待。而重入锁可以响应中断,使得线程在迟迟得不到锁的情况下,不用再等待。主要由lockInterruptibly()实现,这是一个可以对中断进行响应的锁申请动作,锁中断可以避免死锁。

2、锁的申请可以有等待时限,用tryLock()可以实现限时等待,如果超时还未获得锁会返回false,也防止线程迟迟得不到锁时一直等待,可以避免死锁。

3、公平锁,即锁的获得按照线程先来后到的顺序依次获得,不会产生饥饿现象。sync的锁默认不公平,可通过传入构造方法的参数实现公平锁。

4、重入锁可以绑定多个Condition条件,这些Condition通过调用await/singal实现线程间通信。





4.




4

posted @ 2019-12-14 21:32  琉璃青了谁的眸  阅读(263)  评论(0编辑  收藏  举报