Executor
Executor 管理多個異步任務(wù)的執(zhí)行,而無需程序員顯式地管理線程的生命周期。這里的異步是指多個任務(wù)的執(zhí)行互不干擾,不需要進行同步操作。
主要有三種 Executor:
1.CachedThreadPool: 一個任務(wù)創(chuàng)建一個線程;
2.FixedThreadPool: 所有任務(wù)只能使用固定大小的線程;
3.SingleThreadExecutor: 相當(dāng)于大小為 1 的 FixedThreadPool。
Daemon
守護線程是程序運行時在后臺提供服務(wù)的線程,不屬于程序中不可或缺的部分。
當(dāng)所有非守護線程結(jié)束時,程序也就終止,同時會殺死所有守護線程。
main() 屬于非守護線程。使用 setDaemon() 方法將一個線程設(shè)置為守護線程。
sleep()
Thread.sleep(millisec) 方法會休眠當(dāng)前正在執(zhí)行的線程,millisec 單位為毫秒。
sleep() 可能會拋出 InterruptedException,因為異常不能跨線程傳播回 main() 中,因此必須在本地進行處理。線程中拋出的其它異常也同樣需要在本地進行處理。
yield()
對靜態(tài)方法 Thread.yield() 的調(diào)用聲明了當(dāng)前線程已經(jīng)完成了生命周期中最重要的部分,可以切換給其它線程來執(zhí)行。該方法只是對線程調(diào)度器的一個建議,而且也只是建議具有相同優(yōu)先級的其它線程可以運行。