這篇文章主要介紹“java yield()和sleep()的區(qū)別是什么”,在日常操作中,相信很多人在java yield()和sleep()的區(qū)別是什么問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對(duì)大家解答”java yield()和sleep()的區(qū)別是什么”的疑惑有所幫助!接下來,請(qǐng)跟著小編一起來學(xué)習(xí)吧!
創(chuàng)新互聯(lián)公司主營皋蘭網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營網(wǎng)站建設(shè)方案,成都APP應(yīng)用開發(fā),皋蘭h5小程序定制開發(fā)搭建,皋蘭網(wǎng)站營銷推廣歡迎皋蘭等地區(qū)企業(yè)咨詢
區(qū)別
1、sleep()會(huì)導(dǎo)致當(dāng)前線程暫停指定的時(shí)間,沒有CPU時(shí)間片的消耗
2、yield()只是對(duì)CPU調(diào)度器的一個(gè)提示,如果CPU調(diào)度器沒有忽略這個(gè)提示,會(huì)導(dǎo)致線程上下文的切換
sleep()會(huì)使線程短暫阻塞,在給定時(shí)間內(nèi)釋放CPU資源
如果yield()生效,yield()會(huì)使得從RUNNING狀態(tài)進(jìn)入RUNNABLE狀態(tài)
sleep()會(huì)幾乎百分百地完成給定時(shí)間的休眠,但是yield()的提示不一定能擔(dān)保
一個(gè)線程調(diào)用sleep()而另一個(gè)線程調(diào)用interrupt()會(huì)捕獲到中斷信號(hào),而yield則不會(huì)
實(shí)例
package cn.hanquan.test; /* * sleep模擬倒計(jì)時(shí),每一秒減一 */ public class Lambda { public static void main(String[] args) { // Labmda表達(dá)式 new Thread(() -> { for (int i = 0; i < 100; i++) { System.out.println(i); try { Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } } }).start(); } }
到此,關(guān)于“java yield()和sleep()的區(qū)別是什么”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!