亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java yield()線程讓步實現(xiàn)過程解析

 更新時間:2020年03月24日 15:49:39   作者:平凡希  
這篇文章主要介紹了Java yield()線程讓步實現(xiàn)過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下

一、yield()介紹

yield()的作用是讓步。它能讓當(dāng)前線程由“運行狀態(tài)”進(jìn)入到“就緒狀態(tài)”,從而讓其它具有相同優(yōu)先級的等待線程獲取執(zhí)行權(quán);但是,并不能保證在當(dāng)前線程調(diào)用yield()之后,其它具有相同優(yōu)先級的線程就一定能獲得執(zhí)行權(quán);也有可能是當(dāng)前線程又進(jìn)入到“運行狀態(tài)”繼續(xù)運行!

二、yield()示例

下面,通過示例查看它的用法。

package com.demo.Thread;

public class Thread1 extends Thread{
  
  public Thread1(String name){
    super(name);
  }
  public synchronized void run(){
    for(int i=0; i <10; i++){ 
      System.out.printf("%s [%d]:%d\n", this.getName(), this.getPriority(), i); 
      // i整除4時,調(diào)用yield
      if (i%4 == 0){
        Thread.yield();
      }
    } 
  }
}

package com.demo.Thread;
public class YieldTest {
  public static void main(String[] args){
    Thread1 t1 = new Thread1("t1");
    Thread1 t2 = new Thread1("t2");
    
    t1.start();
    t2.start();
    
  }

}

(某一次的)運行結(jié)果:

t1 [5]:0
t2 [5]:0
t1 [5]:1
t1 [5]:2
t1 [5]:3
t1 [5]:4
t1 [5]:5
t1 [5]:6
t1 [5]:7
t1 [5]:8
t1 [5]:9
t2 [5]:1
t2 [5]:2
t2 [5]:3
t2 [5]:4
t2 [5]:5
t2 [5]:6
t2 [5]:7
t2 [5]:8
t2 [5]:9

結(jié)果說明:

“線程t1”在能被4整數(shù)的時候,并沒有切換到“線程t2”。這表明,yield()雖然可以讓線程由“運行狀態(tài)”進(jìn)入到“就緒狀態(tài)”;但是,它不一定會讓其它線程獲取CPU執(zhí)行權(quán)(即,其它線程進(jìn)入到“運行狀態(tài)”),即使這個“其它線程”與當(dāng)前調(diào)用yield()的線程具有相同的優(yōu)先級。

三、yield() 與 wait()的比較

我們知道,wait()的作用是讓當(dāng)前線程由“運行狀態(tài)”進(jìn)入“等待(阻塞)狀態(tài)”的同時,也會釋放同步鎖。而yield()的作用是讓步,它也會讓當(dāng)前線程離開“運行狀態(tài)”。它們的區(qū)別是:

(01) wait()是讓線程由“運行狀態(tài)”進(jìn)入到“等待(阻塞)狀態(tài)”,而yield()是讓線程由“運行狀態(tài)”進(jìn)入到“就緒狀態(tài)”。

(02) wait()是會讓線程釋放它所持有對象的同步鎖,而yield()方法不會釋放鎖。

下面通過示例演示yield()是不會釋放鎖的。

package com.demo.Thread;

public class YieldLockTest {
  
  private static Object obj = new Object();
  
  public static void main(String[] args){
    ThreadA t1 = new ThreadA("t1");
    ThreadA t2 = new ThreadA("t2");
    
    t1.start();
    t2.start();
  }

  static class ThreadA extends Thread{
    
    public ThreadA(String name){
      super(name);
    }
    public void run(){
      //獲取obj對象的同步鎖
      synchronized(obj){
        for(int i=0; i <10; i++){ 
          System.out.printf("%s [%d]:%d\n", this.getName(), this.getPriority(), i); 
          // i整除4時,調(diào)用yield
          if (i%4 == 0){
            Thread.yield();
          } 
        }
      }
    }
  }
}

(某一次)運行結(jié)果:

t1 [5]:0
t1 [5]:1
t1 [5]:2
t1 [5]:3
t1 [5]:4
t1 [5]:5
t1 [5]:6
t1 [5]:7
t1 [5]:8
t1 [5]:9
t2 [5]:0
t2 [5]:1
t2 [5]:2
t2 [5]:3
t2 [5]:4
t2 [5]:5
t2 [5]:6
t2 [5]:7
t2 [5]:8
t2 [5]:9

結(jié)果說明:

主線程main中啟動了兩個線程t1和t2。t1和t2在run()會引用同一個對象的同步鎖,即synchronized(obj)。在t1運行過程中,雖然它會調(diào)用Thread.yield();但是,t2是不會獲取cpu執(zhí)行權(quán)的。因為,t1并沒有釋放“obj所持有的同步鎖”!

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論