对象等待集

1  对象等待集

1.1 背景:

一个线程频繁加锁解锁,占用CPU,导致其他线程无法获取到CPU,其他进程“饿死”。

1.2  wait/notify

 让程序员有一定的办法干预线程调度。

线程的调度本来是完全由内核全权负责的,但是这样的抢占式执行可能会带来很多问题(线程饿死)。

wait方法:当操作条件不成熟,就等待。

notify方法:当操作条件成熟时,通知指定的线程来工作。

wait  调用的时候就会阻塞,一直阻塞到有其他线程调用对应的notify为止。

wait和notify 都必须搭配 synchronized来使用。

wait本质做了三件事

1.释放锁

2.等待通知  前两个条件是原子的,为了避免竞态条件问题

3.尝试重新获取锁并继续执行

wait和sleep的区别

wait/notify 机制 一定程度的影响线程调度

sleep 是让当前线程休眠

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值