線程組
線程是被個別創建的,但可以將它們歸類到線程組中,以便於調試和監視。只能在創建線程的同時將它與一個線程組相關聯。在使用大量線程的程序中,使用線程組組織線程可能很有幫助。可以將它們看作是計算機上的目錄和文件結構。
線程間發信
當線程在繼續執行前需要等待一個條件時,僅有 synchronized 關鍵字是不夠的。雖然 synchronized 關鍵字阻止並發更新一個對象,但它沒有實現線程間發信。Object 類為此提供了三個函數:wait()、notify() 和 notifyAll()。以全球氣候預測程序為例。這些程序通過將地球分為許多單元,在每個循環中,每個單元的計算都是隔離進行的,直到這些值趨於穩定,然後相鄰單元之間就會交換一些數據。所以,從本質上講,在每個循環中各個線程都必須等待所有線程完成各自的任務以後才能進入下一個循環。這個模型稱為 屏蔽同步。
屏蔽同步
當對一個線程調用wait()時,該線程就被有效阻塞,只到另一個線程對同一個對象調用notify()或notifyAll()為止。因此,在前一個示例中,不同的線程在完成他們的工作以後將調用waitForAll()函數,最後一個線程將觸發notifyAll()函數,該函數將釋放所有的線程。第三個函數 notify() 只通知一個正在等待的線程,當對每次只能由一個線程使用的資源進行訪問限制時,這個函數很有用。但是,不可能預知哪個線程會獲得這個通知,因為這取決於 Java 虛擬機 (JVM) 調度算法。
將 CPU 讓給另一個線程
當線程放棄某個稀有的資源(如數據庫連接或網絡端口)時,它可能調用 yIEld() 函數臨時降低自己的優先級,以便某個其他線程程能夠運行。
守護線程
有兩類線程:用戶線程和守護線程。用戶線程是那些完成有用工作的線程。 守護線程是那些僅提供輔助功能的線程。Thread 類提供了 setDaemon() 函數。Java 程序將運行到所有用戶線程程終止,然後它將破壞所有的守護線程。在 Java 虛擬機 (JVM) 中,即使在 main 結束以後,如果另一個用戶線程仍在運行,則程序仍然可以繼續運行。