當(dāng)前位置: 首頁(yè)IT技術(shù) → 線程中sleep()與wait()區(qū)別

線程中sleep()與wait()區(qū)別

更多

  sleep是讓線程暫停指定的時(shí)間,wait是讓線程等待,知道有notify方法出現(xiàn)在繼續(xù)運(yùn)行,sleep不釋放對(duì)象鎖,wait釋放對(duì)象鎖。這在很多地方都有寫(xiě)到,但沒(méi)有例子不好理解

  import java.util.ArrayList; import java.util.List; public class thread { public List list=new ArrayList(); Integer i=0;//新建一個(gè)對(duì)象,隨便什么,就為了借用它的鎖而已。 public static void main(String[] args){ thread th=new thread(); A a=th.new A(); B b=th.new B(); Thread add=new Thread(a); Thread get=new Thread(b); add.start(); get.start(); } class A extends Thread{ public void run(){ synchronized(i){ try { //Thread.sleep(1000); i.wait();//這里調(diào)用了對(duì)象i的wait方法,那么就表示所在線程暫時(shí)放棄i的對(duì)象鎖,并阻塞在這里,同時(shí)把機(jī)會(huì)讓給同樣使用i鎖的B線程執(zhí)行 } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } for(int j=0;j

  從如上代碼中可見(jiàn),線程B是負(fù)責(zé)向集合中加值的,線程A是負(fù)責(zé)從集合中取值的,如果不進(jìn)行同步處理,那么如果兩個(gè)線程同時(shí)運(yùn)行,那么A可能在B加入值之前就從集合中取值,那么就會(huì)報(bào)錯(cuò),所以必須進(jìn)行同步代碼的操作(也可以加入flag來(lái)判斷是否到了A中從集合里取值的時(shí)機(jī))。

  而用sleep就沒(méi)有上面的功能了,因?yàn)閺拇a中可以發(fā)現(xiàn),不管是A線程先搶到cpu開(kāi)始執(zhí)行還是B線程先執(zhí)行,他們中的一個(gè)肯定會(huì)拿到i的鎖的,但拿到后i的鎖就沒(méi)有使用wait方法釋放過(guò),那假設(shè)B先拿到鎖了,向list中加入值完成了,那也別指望A能打印出來(lái),因?yàn)锳一直阻塞在(i){  

熱門(mén)評(píng)論
最新評(píng)論
發(fā)表評(píng)論 查看所有評(píng)論(0)
昵稱(chēng):
表情: 高興 可 汗 我不要 害羞 好 下下下 送花 屎 親親
字?jǐn)?shù): 0/500 (您的評(píng)論需要經(jīng)過(guò)審核才能顯示)