代码:
先调用unpark的话park不会停下来。
------
park和unpark的底层实现原理:
---04--- 59 60 附加在别的地方有 ---
线程的状态:new runnable block waiting timewaiting terminated
---04- 61 --
代码:
---
首先是wait状态
---
然后是BLOCK就是Monitor
---
---
---04- 62 64---
---
多把锁就是细粒度的锁可能会代理爱死锁:
---
定位死锁:
jsp
jstack 进程ID
jconsole有检测死锁的按钮。
---04- 65 66 67 ---
哲学家就餐:
---04- 68 --
活锁。
活锁就是分别改变对方的值,导致都到不了结束的条件。
活锁和饥饿:https://www.cnblogs.com/ConstXiong/p/11688000.html
package cn.itcast.n4;
import lombok.extern.slf4j.Slf4j;
import static cn.itcast.n2.util.Sleeper.sleep;
@Slf4j(topic = "c.TestLiveLock")
public class TestLiveLock {
static volatile int count = 10;
static final Object lock = new Object();
public static void main(String[] args) {
new Thread(() -> {
// 期望减到 0 退出循环
while (count > 0) {
sleep(0.2);
count--;
log.debug("count: {}", count);
}
}, "t1").start();
new Thread(() -> {
// 期望超过 20 退出循环
while (count < 20) {
sleep(0.2);
count++;
log.debug("count: {}", count);
}
}, "t2").start();
}
}
---04 69 ---
没有死锁但是其他的人得到的机会太少了。
哲学家可以展示饥饿问题。
---04- 70 --