1.一些基本概念
1)線程 進程
進程則可以說是一個程序,一個app,而線程是cpu執(zhí)行的最小單元,是一個順序執(zhí)行流。
當一個程序進入內存運行時,即變成一個進程。進程是處于運行過程中的程序,具有一定的獨立功能。
如果說一個進程是一個公司,那么一個線程則是一個員工。
同一個公司里,不同員工是共享一些資源的,比如飲水機、打印機。而不同公司的話,這些資源是獨立的。
2)并行 并發(fā)
并行指在同一時刻,有多條指令在多個處理器上同時執(zhí)行
并發(fā)是指同一個時刻只能有一條指令執(zhí)行,但多個進程指令被快速輪換執(zhí)行。
并行
對應了鳴人的多重影分身,同一時間,所有的分身都是真的,都可以干活。
而并發(fā)
對應了龜仙人的殘像拳,只有一個才是真的,只是在高速切換而已。
2.線程的生命周期
線程有5種狀態(tài),分別是new,runnable,running,blocked,dead
.
1)new
新建狀態(tài)
很好記,剛new
了一個thread()
,它就是new
狀態(tài),新建狀態(tài)。線程剛剛創(chuàng)建完畢,此時線程和普通的對象一樣,jvm也剛剛分配內存給它,也初始化這個實例的成員變量,線程還沒有開始啟動。也只有這個狀態(tài)的線程,可以調用start()
來啟動線程。
2)runnable
就緒狀態(tài)
當一個線程對象調用了start()
以后,這個線程就處于就緒狀態(tài)了。注意,至于這個線程什么時候開始運行,取決于JVM里線程調度器的調度。處于這個狀態(tài),僅僅表示,這個線程可以運行了。并不是一start()
就馬上就是運行狀態(tài)了。
3)running
運行狀態(tài)和blocked
阻塞狀態(tài)
如果一個處于runnable
狀態(tài)的線程獲得了CPU,獲得了寵幸,則開始執(zhí)行run()
了,亦即線程執(zhí)行體,我們就說這個線程處于運行狀態(tài)。
但一個線程開始運行后,它不可能一直處于運行狀態(tài)。講道理,它會被阻塞,以便讓其他線程獲得執(zhí)行的機會。不同的平臺采用的策略不同。對于采用了搶占式策略的系統(tǒng)而言,阻塞了這個線程然后選擇下一個線程的時候,系統(tǒng)會考慮線程的優(yōu)先級。
除了系統(tǒng)主動阻塞,還有線程主動進入阻塞狀態(tài),這一部分我會在線程控制中講到。
但總之,被阻塞的線程會在合適的時候重新進入runnable
就緒狀態(tài),注意不是running
運行狀態(tài)。所以線程什么時候重新再執(zhí)行,如上面所說,是等線程調度器的調度的。
4)dead
死亡狀態(tài)
線程有3種死法
1.
run()
或者call()
方法執(zhí)行完成,線程正常結束
2.線程拋出異常
3.直接調用該線程的stop()
,但這個方法不推薦使用,因為會導致死鎖
注意,除非是守護線程,否則子線程啟動起來后,它就擁有和主線程相同的地位,也就是說,即便主線程結束,其他的線程也不受影響,并不會隨之結束。這里要注意內存泄漏問題。
3.線程控制
大量代碼,待續(xù)