山近月远觉月小,便道此山大于月。
若人有眼大如天,当见山高月更阔。
关于Thread的 yield() 方法,在实际的开发过程中,说实话真的是很不常见。但是在面试过程中怕是司空见惯啦。
正由于其开发中几乎见不到它的身影,一般情况下,我也懒得去理它。但是由于最近在回顾Kotlin Coroutine相关内容时,再次见到了它的身影,那么看起来绕不开它。
咳咳咳~~,扶我起来…
1. 单词yield
在英语中,yield means to let go, to give up, to surrender. 翻译过来就是:『让步,放弃,投降』。
2. yield()的作用
调用yield()的线程——告诉JVM我情愿让出CPU,让其他的线程先运行,这点也注定该线程不会做太重要的任务。
需要注意的是,这仅仅是该线程向CPU提出自己的想法,具体CPU怎么安排是不确定的。这也意味着是不能保证达到预期效果的。所以不必对此报太大希望。(PS:在生成环境中,我们确实不敢这么用它。)
/**
* A hint to the scheduler that the current thread is willing to yield
* its current use of a processor. The scheduler is free to ignore this
* hint.
*/
public static native void yield();
通过源码的注释,我们也可以窥探一二…
3. wait,sleep,join,yield的区别
- yield() VS wait()
a. wait()只能在synchronized代码块或者方法中去调用,而yield()没有此限制。
b. wait()可以指定一段时间去尝试切换线程的调度。
c. wait()可以在任意时间调用notify()或者notifyAll()来唤醒线程。 - yield() VS sleep()
sleep()可以在其参数设置的时间内强制挂起当前线程,而yield()并不能保证其效果。
- yield() VS join()
join()方法让调用线程执行完毕(或者执行规定的时间),其它线程才能继续执行。
4. 总结
yield()虽然可能让出CPU,但是由于不能保证一定能让出CPU,所以显得很鸡肋。