進(jìn)程
進(jìn)程(process)是程序的運(yùn)行實(shí)例
運(yùn)行一個(gè)Java程序的實(shí)質(zhì)是啟動(dòng)一個(gè)Java虛擬機(jī)進(jìn)程
進(jìn)程是程序向操作系統(tǒng)申請資源(如內(nèi)存空間铁瞒、文件句柄)的基本單位
線程
線程(Thread)是進(jìn)程中可獨(dú)立執(zhí)行的最小單位
一個(gè)進(jìn)程可以包含多個(gè)線程
同一個(gè)進(jìn)程中的所有線程共享該進(jìn)程中的資源
線程要完成的計(jì)算稱為任務(wù)
start
方法只能調(diào)用一次,否則會(huì)跑出IlegalThreadStateException
創(chuàng)建一個(gè)線程與創(chuàng)建其他類型的Java對象不同的是屑那,Java虛擬機(jī)會(huì)為每個(gè)線程分配調(diào)用棧(Call Stack)所需的內(nèi)存空間
調(diào)用棧用于跟蹤Java代碼(方法)間的調(diào)用關(guān)系以及Java代碼對本地代碼(Native Code)的調(diào)用
創(chuàng)建線程對象比創(chuàng)建其他類型的成本要高一些
線程的屬性(除了id
外)都是可讀寫的屬性
Java線程的優(yōu)先級并不能保證線程按照其優(yōu)先級高低的順序執(zhí)行
守護(hù)線程
線程的daemon屬性來設(shè)置是否是守護(hù)線程
守護(hù)線程(Daemon Thread)不會(huì)影響虛擬機(jī)的正常停止
一個(gè)Java虛擬機(jī)只有在其所有的用戶線程(非守護(hù)線程)都運(yùn)行結(jié)束的情況下才能正常停止
一個(gè)線程是否是一個(gè)守護(hù)線程默認(rèn)情況下取決于其父線程是否是守護(hù)線程,也就是說默認(rèn)情況下硼婿,老子是啥骤肛,兒子就是啥
一個(gè)線程的優(yōu)先級默認(rèn)為該父線程的優(yōu)先級,還是那句話苔可,默認(rèn)情況下,老子是啥袋狞,兒子就是啥
父線程和子線程之間的生命周期沒有必然聯(lián)系
線程的生命周期
一個(gè)線程在整個(gè)生命周期過程中焚辅,有且僅有一次
是出于New狀態(tài)
和Terminated狀態(tài)
的
線程轉(zhuǎn)儲(Thread Dump)
jstack -l PID
jvisualvm
Java Mission Control(JMC)
多線程的優(yōu)勢和風(fēng)險(xiǎn)
優(yōu)勢
- 提高系統(tǒng)的吞吐率(Throughout)
- 提高系統(tǒng)的響應(yīng)性(Responsiveness)
- 充分利用多核處理器資源
- 最小化系統(tǒng)對資源的使用----資源共享
風(fēng)險(xiǎn)
- 線程安全問題
- 線程活性(Thread Liveness)問題
死鎖 活鎖 線程饑餓 - 上下文切換(Context Switch)
- 可靠性