-
结论:当sleep写在synchronized里面的时候,当前线程会休眠,让出cpu,但是synchronized不会解锁,synchronized锁定的方法或者代码块不会往下执行,临界资源别的线程不能用。
-
结论:当sleep写在synchronized外面的时候,当前线程会休眠,让出cpu,写在外面就和锁没关系了,临界资源别的线程也就可以用了,只不过是让当前线程休息一会罢了。
- 结论出场景:来自于java实验课的一个多线程售票实验(花了一下午才明白其中的奥秘)
- 题目要求:
-
一开始我也是上网找一些栗子:(大多是类似于下面这种写法,把sleep写在锁里面)
但是,我发现这种理解是错误的,因为他这个sleep写在了锁里面,即使当前线程休眠,让出cpu,但是不会解锁,也就是临界资源不会被其他线程使用,那么其他线程还怎么卖票呢?而且这也不符合显示中的场景,假如一个窗口要1-3秒才出售一张票,并不是真正锁住票1-3秒,真正需要锁住的只有那减少票余数的那几微秒罢了。所以为了模拟一个窗口卖一张票1-3秒,只需要让当前线程休眠1-3秒,而不锁定票资源,把sleep写在锁外面就好了。