六月婷婷综合激情-六月婷婷综合-六月婷婷在线观看-六月婷婷在线-亚洲黄色在线网站-亚洲黄色在线观看网站

明輝手游網中心:是一個免費提供流行視頻軟件教程、在線學習分享的學習平臺!

淺析Java多線程編程中的高級技術

[摘要]線程組   線程是被個別創建的,但可以將它們歸類到線程組中,以便于調試和監視。只能在創建線程的同時將它與一個線程組相關聯。在使用大量線程的程序中,使用線程組組織線程可能很有幫助。可以將它們看作是計算機上的目錄和文件結構。   線程間發信   當線程在繼續執行前需要等待一個條件時,僅有 synchr...
線程組

  線程是被個別創建的,但可以將它們歸類到線程組中,以便于調試和監視。只能在創建線程的同時將它與一個線程組相關聯。在使用大量線程的程序中,使用線程組組織線程可能很有幫助。可以將它們看作是計算機上的目錄和文件結構。

  線程間發信

  當線程在繼續執行前需要等待一個條件時,僅有 synchronized 關鍵字是不夠的。雖然 synchronized 關鍵字阻止并發更新一個對象,但它沒有實現線程間發信。Object 類為此提供了三個函數:wait()、notify() 和 notifyAll()。以全球氣候預測程序為例。這些程序通過將地球分為許多單元,在每個循環中,每個單元的計算都是隔離進行的,直到這些值趨于穩定,然后相鄰單元之間就會交換一些數據。所以,從本質上講,在每個循環中各個線程都必須等待所有線程完成各自的任務以后才能進入下一個循環。這個模型稱為 屏蔽同步,下例說明了這個模型:

  屏蔽同步

  public class BSync {
   int totalThreads;
   int currentThreads;

   public BSync(int x) {
   totalThreads = x;
   currentThreads = 0;
   }

   public synchronized void waitForAll() {
   currentThreads++;
   if(currentThreads < totalthreads)="" {="">
    try {
     wait();
    } catch (Exception e) {}
   }
   else {
    currentThreads = 0;
    notifyAll();
   }
   }
  }

  當對一個線程調用 wait() 時,該線程就被有效阻塞,只到另一個線程對同一個對象調用 notify() 或 notifyAll() 為止。因此,在前一個示例中,不同的線程在完成它們的工作以后將調用 waitForAll() 函數,最后一個線程將觸發 notifyAll() 函數,該函數將釋放所有的線程。第三個函數 notify() 只通知一個正在等待的線程,當對每次只能由一個線程使用的資源進行訪問限制時,這個函數很有用。但是,不可能預知哪個線程會獲得這個通知,因為這取決于 Java 虛擬機 (JVM) 調度算法。

  將 CPU 讓給另一個線程

  當線程放棄某個稀有的資源(如數據庫連接或網絡端口)時,它可能調用 yield() 函數臨時降低自己的優先級,以便某個其他線程能夠運行。

  守護線程

  有兩類線程:用戶線程和守護線程。用戶線程是那些完成有用工作的線程。 守護線程是那些僅提供輔助功能的線程。Thread 類提供了 setDaemon() 函數。Java 程序將運行到所有用戶線程終止,然后它將破壞所有的守護線程。在 Java 虛擬機 (JVM) 中,即使在 main 結束以后,如果另一個用戶線程仍在運行,則程序仍然可以繼續運行。

  避免不提倡使用的方法

  不提倡使用的方法是為支持向后兼容性而保留的那些方法,它們在以后的版本中可能出現,也可能不出現。Java 多線程支持在版本 1.1 和版本 1.2 中做了重大修訂,stop()、suspend() 和 resume() 函數已不提倡使用。這些函數在 JVM 中可能引入微妙的錯誤。雖然函數名可能聽起來很誘人,但請抵制誘惑不要使用它們。

  調試線程化的程序

  在線程化的程序中,可能發生的某些常見而討厭的情況是死鎖、活鎖、內存損壞和資源耗盡。

  死鎖

  死鎖可能是多線程程序最常見的問題。當一個線程需要一個資源而另一個線程持有該資源的鎖時,就會發生死鎖。這種情況通常很難檢測。但是,解決方案卻相當好:在所有的線程中按相同的次序獲取所有資源鎖。例如,如果有四個資源 ?A、B、C 和 D ? 并且一個線程可能要獲取四個資源中任何一個資源的鎖,則請確保在獲取對 B 的鎖之前首先獲取對 A 的鎖,依此類推。如果“線程 1”希望獲取對 B 和 C 的鎖,而“線程 2”獲取了 A、C 和 D 的鎖,則這一技術可能導致阻塞,但它永遠不會在這四個鎖上造成死鎖。

  活鎖

  當一個線程忙于接受新任務以致它永遠沒有機會完成任何任務時,就會發生活鎖。這個線程最終將超出緩沖區并導致程序崩潰。試想一個秘書需要錄入一封信,但她一直在忙于接電話,所以這封信永遠不會被錄入。 內存損壞

  如果明智地使用 synchronized 關鍵字,則完全可以避免內存錯誤這種氣死人的問題。

  資源耗盡

  某些系統資源是有限的,如文件描述符。多線程程序可能耗盡資源,因為每個線程都可能希望有一個這樣的資源。如果線程數相當大,或者某個資源的侯選線程數遠遠超過了可用的資源數,則最好使用 資源池。一個最好的示例是數據庫連接池。只要線程需要使用一個數據庫連接,它就從池中取出一個,使用以后再將它返回池中。資源池也稱為 資源庫。

  調試大量的線程

  有時一個程序因為有大量的線程在運行而極難調試。在這種情況下,下面的這個類可能會派上用場:

  public class Probe extends Thread {
   public Probe() {}
   public void run() {
   while(true) {
    Thread[] x = new Thread[100];
    Thread.enumerate(x);
    for(int i=0; i<100; i++)="" {="">
     Thread t = x[i];
     if(t == null)
      break;
     else
      System.out.println(t.getName() + "\t" + t.getPriority()+ "\t" + t.isAlive() + "\t" + t.isDaemon());
    }
   }
   }
  }

  限制線程優先級和調度

  Java 線程模型涉及可以動態更改的線程優先級。本質上,線程的優先級是從 1 到 10 之間的一個數字,數字越大表明任務越緊急。JVM 標準首先調用優先級較高的線程,然后才調用優先級較低的線程。但是,該標準對具有相同優先級的線程的處理是隨機的。如何處理這些線程取決于基層的操作系統策略。在某些情況下,優先級相同的線程分時運行;在另一些情況下,線程將一直運行到結束。請記住,Java 支持 10 個優先級,基層操作系統支持的優先級可能要少得多,這樣會造成一些混亂。因此,只能將優先級作為一種很粗略的工具使用。最后的控制可以通過明智地使用 yield() 函數來完成。通常情況下,請不要依靠線程優先級來控制線程的狀態。

  小結

  本文說明了在 Java 程序中如何使用線程。像是否應該使用線程這樣的更重要的問題在很大程序上取決于手頭的應用程序。決定是否在應用程序中使用多線程的一種方法是,估計可以并行運行的代碼量。并記住以下幾點:

  使用多線程不會增加 CPU 的能力。但是如果使用 JVM 的本地線程實現,則不同的線程可以在不同的處理器上同時運行(在多 CPU 的機器中),從而使多 CPU 機器得到充分利用。

  如果應用程序是計算密集型的,并受 CPU 功能的制約,則只有多 CPU 機器能夠從更多的線程中受益。

  當應用程序必須等待緩慢的資源(如網絡連接或數據庫連接)時,或者當應用程序是非交互式的時,多線程通常是有利的。

  基于 Internet 的軟件有必要是多線程的;否則,用戶將感覺應用程序反映遲鈍。例如,當開發要支持大量客戶機的服務器時,多線程可以使編程較為容易。在這種情況下,每個線程可以為不同的客戶或客戶組服務,從而縮短了響應時間。 某些程序員可能在 C 和其他語言中使用過線程,在那些語言中對線程沒有語言支持。這些程序員可能通常都被搞得對線程失去了信心。



主站蜘蛛池模板: 天天弄天天操 | 亚洲国产成人久久99精品 | 在线亚洲精品中文字幕美乳 | 日韩精品福利视频一区二区三区 | 特黄视频| 四虎在线视频 | 日韩一级在线播放免费观看 | 手机在线看片国产日韩生活片 | 亚洲 日本 欧美 日韩精品 | 青青青青青视频免费播放 | 亚洲欧美日韩国产 | 天天做日日爱 | 天天影视色香欲综合网小说 | 午夜无遮挡怕怕怕免费视频 | 羞羞色在线 | 日本激情视频网站 | 一区二区三区久久 | 日本欧美视频在线观看 | 一级做a爰片久久毛片下载 一级做a爰片久久毛片图片 | 天天上天天操 | 探花系列 | 天天干天天干天天干天天干天天干 | 日韩亚射| 日本中文字幕网址 | 午夜精品久久久久久中宇 | 午夜久久久久久久 | 午夜影院a| 亚洲第一色视频 | 日韩在线黄色 | 天堂v| 小明永久成人一区二区 | 中文字幕一二三四区 | 日本一区二区在线不卡 | 日本红怡院亚洲红怡院最新 | 网站久久 | 香蕉免费一级视频在线观看 | 欧美性xxxx| 日本动态120秒免费 日本叼嗨 | 午夜在线亚洲男人午在线 | 天天干天天射天天插 | 日韩理论片在线观看电视 |