java并发学习——wait,sleep,notify,notifyAll方法的总结

(1)几个Object类中涉及到线程并发的理解和比较(简说,后续会写详细):

1.wait方法和sleep方法的比较:

在调用wait方法时,线程必须要持有被调用对象的锁,当调用wait方法后,线程就会释放掉该对象的锁(monitor)。

在调用Thread类的sleep方法时,线程不会释放掉对象的锁。

2.关于wait与notify和notifyAll方法的总结:

(1)当调用wait方法时,首先需要确保调用了wait方法的线程已经持有了对象的锁。

(2)当调用wait方法后,该线程就会释放掉这个对象的锁,然后进入到等待状态,也可以说进入到该对象的等待集合中。(wait set)

(3)当线程调用了wait后进入等待状态时,它就可以等待其它线程调用相同对象的notify或notifyAll方法来使得自己被唤醒。

(4)一旦这个线程被其它线程唤醒后,该线程就会与其他线程一同开始竞争这个对象的锁(公平竞争);只有当该线程获取到了这个对象的锁后,线程才会继续往下执行。

(5)调用wait方法的代码片段需要放在一个synchronized块或是synchronized方法中,这样才可以确保线程在调用wait方法前已经获取到了对象的锁。

(6)当调用对象的notify方法时,它会随机唤醒该对象等待集合(wait set)中的任意一个线程,当某个线程被唤醒后,它就会与其他线程一同竞争对象的锁

(7)当调用对象的notifyAll方法时,它会唤醒该对象等待集合(wait set)中的所有线程,这些线程被唤醒后,又会开始竞争对象的锁。

(8)在某一时刻,只有唯一一个线程可以拥有对象的锁。

代码示例:

1.存在一个对象,该对象有一个int类型的成员变量counter,该成员变量的初始值为0.

2.创建两个线程,其中一个线程对该对象的成员变量counter加1,另一个线程对该对象的成员变量减1.

3.输出该对象成员变量counter每次变化后的值,10101010......交替打印。

当增加和减少线程由原先的一对增加到四个(两加两减)之后,需要将increase和decrease方法中同步方法中的if判断改成while,原题成立。在多线程中,无法保证只有一个线程(增加或减少)进入同步方法,所以需要将counter加while循环,保证同步变量满足的条件。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值