多執行緒是同時執行多個執行緒的過程。 它允許您獨立執行多個操作。可以通過使用多執行緒來實現多工。執行緒是輕量級的子進程,佔用較少的記憶體。多執行緒用於在Scala中開發並行應用程式。
Scala不提供用於建立執行緒的任何單獨的庫。如果您熟悉Java的多執行緒概念,那麼將會了解到它與Scala語言本身的語法相似。
可以通過擴充套件Thread
類或Runnable
介面來建立執行緒。兩者都提供了執行方法來提供具體的實現。
執行緒生命週期是執行緒開始和終止的時間跨度。它有各種各樣的階段,如新,可執行,終止,阻止等。執行緒類提供了各種方法來監視執行緒的狀態。
Scala執行緒狀態如下:
1. 新建(New)
這是執行緒的第一個狀態,在新執行緒開始之前。
2. 可執行(Runnable)
這是執行緒已經啟動但是執行緒排程程式沒有選擇它作為正在執行的執行緒的狀態。
3. 執行(Running)
如果執行緒排程程式選擇了該執行緒,則該執行緒處於執行狀態。
4. 不可執行(Non-Runnable - 阻塞)
這是執行緒仍然存在但由於等待輸入或資源而無法執行的狀態。
5. 終止(Terminated)
當run()
方法退出時,執行緒處於終止或死亡狀態。