国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

這么理解線程生命周期,是不是很簡(jiǎn)單?

開(kāi)發(fā) 后端
了解了它們的生命周期后,使用 Spring Bean 好比看到它們的行動(dòng)軌跡,現(xiàn)在使用就一點(diǎn)都不慌了。

為什么要了解線程的生命周期?

之前寫(xiě)過(guò) Spring Bean 生命周期三部曲:

  1.  Spring Bean生命周期之緣起
  2.  Spring Bean生命周期之緣盡
  3.  Spring Aware 到底是什么?

有朋友留言說(shuō):“了解了它們的生命周期后,使用 Spring Bean 好比看到它們的行動(dòng)軌跡,現(xiàn)在使用就一點(diǎn)都不慌了”。我和他一樣,了解事物的生命周期目的很簡(jiǎn)單,唯【不慌】也

[[320328]]

Java 并發(fā)系列 已經(jīng)寫(xiě)了很多,從來(lái)還沒(méi)提起過(guò)那個(gè)它【Java線程生命周期】。有了前序理論圖文的鋪墊,在走進(jìn)源碼世界之前,談?wù)撍臅r(shí)機(jī)恰好到了。因?yàn)椋帉?xiě)并發(fā)程序的核心之一就是正確的擺弄線程狀態(tài)

線程生命周期的幾種狀態(tài)

剛接觸線程生命周期時(shí),我總是記不住,也理解不了他們的狀態(tài),可以說(shuō)是比較混亂,更別說(shuō)它們之間是如何進(jìn)行狀態(tài)轉(zhuǎn)換的了。原因是我把操作系統(tǒng)通用線程狀態(tài)和編程語(yǔ)言封裝后的線程狀態(tài) 概念混淆在一起了

操作系統(tǒng)通用線程狀態(tài)

個(gè)人覺(jué)得通用線程狀態(tài)更符合我們的思考習(xí)慣。其狀態(tài)總共有 5 種 (如下圖)。對(duì)于經(jīng)常寫(xiě)并發(fā)程序的同學(xué)來(lái)說(shuō),其嘴里經(jīng)常念的都是操作系統(tǒng)中的這些通用線程狀態(tài),且看

除去生【初始狀態(tài)】死【終止?fàn)顟B(tài)】,其實(shí)只是三種狀態(tài)的各種轉(zhuǎn)換,聽(tīng)到這句話是不是心情放松了很多呢?

為了更好的說(shuō)明通用線程狀態(tài)和 Java 語(yǔ)言中的線程狀態(tài),這里還是先對(duì)前者進(jìn)行簡(jiǎn)短的說(shuō)明

初始狀態(tài)

線程已被創(chuàng)建,但是還不被允許分配CPU執(zhí)行。注意,這個(gè)被創(chuàng)建其實(shí)是屬于編程語(yǔ)言層面的,實(shí)際在操作系統(tǒng)里,真正的線程還沒(méi)被創(chuàng)建, 比如 Java 語(yǔ)言中的 new Thread()。

可運(yùn)行狀態(tài)

線程可以分配CPU執(zhí)行,這時(shí),操作系統(tǒng)中線程已經(jīng)被創(chuàng)建成功了

運(yùn)行狀態(tài)

操作系統(tǒng)會(huì)為處在可運(yùn)行狀態(tài)的線程分配CPU時(shí)間片,被 CPU 臨幸后,處在可運(yùn)行狀態(tài)的線程就會(huì)變?yōu)檫\(yùn)行狀態(tài)

休眠狀態(tài)

如果處在運(yùn)行狀態(tài)的線程調(diào)用某個(gè)阻塞的API或等待某個(gè)事件條件可用,那么線程就會(huì)轉(zhuǎn)換到休眠狀態(tài),注意:此時(shí)線程會(huì)釋放CPU使用權(quán),休眠的線程永遠(yuǎn)沒(méi)有機(jī)會(huì)獲得CPU使用權(quán),只有當(dāng)?shù)却录霈F(xiàn)后,線程會(huì)從休眠狀態(tài)轉(zhuǎn)換到可運(yùn)行狀態(tài)

終止?fàn)顟B(tài)

線程執(zhí)行完或者出現(xiàn)異常 (被interrupt那種不算的哈,后續(xù)會(huì)說(shuō))就會(huì)進(jìn)入終止?fàn)顟B(tài),正式走到生命的盡頭,沒(méi)有起死回生的機(jī)會(huì)

接下來(lái)就來(lái)看看你熟悉又陌生,面試又經(jīng)常被問(wèn)到的Java 線程生命周期吧

Java語(yǔ)言線程狀態(tài)

在 Thread 的源碼中,定義了一個(gè)枚舉類(lèi) State,里面清晰明了的寫(xiě)了Java語(yǔ)言中線程的6種狀態(tài):

  1.  NEW
  2.  RUNNABLE
  3.  BLOCKED
  4.  WAITING
  5.  TIMED_WAITING
  6.  TERMINATED

這里要做一個(gè)小調(diào)查了,你有查看過(guò)這個(gè)類(lèi)和讀過(guò)其注釋說(shuō)明嗎?(歡迎留言腳印哦)

[[320330]]

耳邊響起五環(huán)之歌,Java中線程狀態(tài)竟然比通用線程狀態(tài)的 5 種多1種,變成了 6 種。這個(gè)看似復(fù)雜,其實(shí)并不是你想的那樣,Java在通用線程狀態(tài)的基礎(chǔ)上,有裁剪,也有豐富,整體來(lái)說(shuō)是少一種。再來(lái)看個(gè)圖,注意顏色區(qū)分哦

Java 語(yǔ)言中

  •  將通用線程狀態(tài)的可運(yùn)行狀態(tài)和運(yùn)行狀態(tài)合并為 Runnable,
  •  將休眠狀態(tài)細(xì)分為三種 (BLOCKED/WAITING/TIMED_WAITING); 反過(guò)來(lái)理解這句話,就是這三種狀態(tài)在操作系統(tǒng)的眼中都是休眠狀態(tài),同樣不會(huì)獲得CPU使用權(quán)

看上圖右側(cè)【Java語(yǔ)言中的線程狀態(tài)】,進(jìn)一步簡(jiǎn)潔的說(shuō),除去線程生死,我們只要玩轉(zhuǎn) RUNNABLE 和休眠狀態(tài)的轉(zhuǎn)換就可以了,編寫(xiě)并發(fā)程序也多數(shù)是這兩種狀態(tài)的轉(zhuǎn)換。所以我們需要了解,有哪些時(shí)機(jī),會(huì)觸發(fā)這些狀態(tài)轉(zhuǎn)換

遠(yuǎn)看看輪廓, 近看看細(xì)節(jié)。我們將上面Java語(yǔ)言中的圖進(jìn)行細(xì)化,將觸發(fā)的節(jié)點(diǎn)放到圖中 (這看似復(fù)雜的圖,其實(shí)三句話就能分解的,所以別慌),且看:

RUNNABLE與BLOCKED狀態(tài)轉(zhuǎn)換

當(dāng)且僅有(just only)一種情況會(huì)從 RUNNABLE 狀態(tài)進(jìn)入到 BLOCKED 狀態(tài),就是線程在等待 synchronized 內(nèi)置隱式鎖;如果等待的線程獲取到了 synchronized 內(nèi)置隱式鎖,也就會(huì)從 BLOCKED 狀態(tài)變?yōu)?RUNNABLE 狀態(tài)了

注意:

上面提到,以操作系統(tǒng)通用狀態(tài)來(lái)看,線程調(diào)用阻塞式 API,會(huì)變?yōu)樾菝郀顟B(tài)(釋放CPU使用權(quán)),但在JVM層面,Java線程狀態(tài)不會(huì)發(fā)生變化,也就是說(shuō)Java線程的狀態(tài)依舊會(huì)保持在 RUNNABLE 狀態(tài)。JVM并不關(guān)心操作系統(tǒng)調(diào)度的狀態(tài)。在JVM看來(lái),等待CPU使用權(quán)(操作系統(tǒng)里是處在可執(zhí)行狀態(tài))與等待I/O(操作系統(tǒng)是處在休眠狀態(tài)),都是等待某個(gè)資源,所以都?xì)w入了RUNNABLE 狀態(tài)

    ​ —— 摘自《Java并發(fā)編程實(shí)戰(zhàn)》

RUNNABLE與WAITING狀態(tài)轉(zhuǎn)換

調(diào)用不帶時(shí)間參數(shù)的等待API,就會(huì)從RUNNABLE狀態(tài)進(jìn)入到WAITING狀態(tài);當(dāng)被喚醒就會(huì)從WAITING進(jìn)入RUNNABLE狀態(tài)

RUNNABLE與 TIMED-WAITING 狀態(tài)轉(zhuǎn)換

調(diào)用帶時(shí)間參數(shù)的等待API,自然就從 RUNNABLE 狀態(tài)進(jìn)入 TIMED-WAITING 狀態(tài);當(dāng)被喚醒或超時(shí)時(shí)間到就會(huì)從TIMED_WAITING進(jìn)入RUNNABLE狀態(tài)

看圖中的轉(zhuǎn)換 API 挺多的,其實(shí)不用擔(dān)心,后續(xù)分析源碼章節(jié),自然就會(huì)記住的,現(xiàn)在有個(gè)印象以及知道狀態(tài)轉(zhuǎn)換的節(jié)點(diǎn)就好了

相信到這里,你看Java線程生命周期的眼神就沒(méi)那么迷惑了,重點(diǎn)就是RUNNABLE與休眠狀態(tài)的切換,接下來(lái)我們看一看,如何查看線程中的狀態(tài),以及具體的代碼觸發(fā)點(diǎn)

如何查看線程處在什么狀態(tài)

程序中調(diào)用 getState() 方法

Thread 類(lèi)中同樣存在 getState() 方法用于查看當(dāng)前線程狀態(tài),該方法就是返回上面提到的枚舉類(lèi) State

NEW

就是上面提到, 編程語(yǔ)言中特有的,通過(guò)繼承 Thread 或?qū)崿F(xiàn) Runnable 接口定義線程后,這時(shí)的狀態(tài)都是 NEW 

  1. Thread thread = new Thread(() -> {});  
  2. System.out.println(thread.getState()); 

RUNNABLE

調(diào)用了 start() 方法之后,線程就處在 RUNNABLE 狀態(tài)了 

  1. Thread thread = new Thread(() -> {});  
  2. thread.start();  
  3. //Thread.sleep(1000);  
  4. System.out.println(thread.getState()); 

BLOCKED

等待 synchronized 內(nèi)置鎖,就會(huì)處在 BLOCKED 狀態(tài) 

  1. public class ThreadStateTest { 
  2.     public static void main(String[] args) throws InterruptedException {  
  3.         Thread t1 = new Thread(new DemoThreadB());  
  4.         Thread t2 = new Thread(new DemoThreadB());  
  5.         t1.start();  
  6.         t2.start(); 
  7.         Thread.sleep(1000);  
  8.         System.out.println((t2.getState()));  
  9.         System.exit(0); 
  10.     }  
  11.  
  12. class DemoThreadB implements Runnable {  
  13.     @Override  
  14.     public void run() {  
  15.         commonResource();  
  16.     }  
  17.     public static synchronized void commonResource() {  
  18.         while(true) {     
  19.          }  
  20.     }  

WAITING

調(diào)用線程的 join() 等方法,從 RUNNABLE 變?yōu)?WAITING 狀態(tài) 

  1. public static void main(String[] args) throws InterruptedException {  
  2.         Thread main = Thread.currentThread();  
  3.         Thread thread2 = new Thread(() -> {  
  4.             try {  
  5.                 Thread.sleep(1000);  
  6.             } catch (InterruptedException e) {  
  7.         Thread.currentThread().interrupt();  
  8.                 e.printStackTrace();  
  9.             }  
  10.             System.out.println(main.getState());  
  11.         });  
  12.         thread2.start();  
  13.         thread2.join();  
  14.     } 

TIMED-WAITING

調(diào)用了 sleep(long) 等方法,線程從 RUNNABLE 變?yōu)?TIMED-WAITING 狀態(tài) 

  1. public static void main(String[] args) throws InterruptedException {  
  2.         Thread thread3 = new Thread(() -> {  
  3.             try {  
  4.                 Thread.sleep(3000);  
  5.             } catch (InterruptedException e) {  
  6.         // 為什么要調(diào)用interrupt方法?  
  7.                 Thread.currentThread().interrupt();  
  8.                 e.printStackTrace();  
  9.             }  
  10.         });  
  11.         thread3.start();  
  12.         Thread.sleep(1000);  
  13.         System.out.println(thread3.getState());  
  14.     } 

TERMINATED

線程執(zhí)行完自然就到了 TERMINATED 狀態(tài)了 

  1. Thread thread = new Thread(() -> {});  
  2. thread.start();  
  3. Thread.sleep(1000);  
  4. System.out.println(thread.getState()); 

以上是程序中查看線程,自己寫(xiě)寫(xiě)測(cè)試看看狀態(tài)還好,現(xiàn)實(shí)中的程序怎么可能允許你加這么多無(wú)用代碼,所以,翠花,上酸菜(jstack)

[[320331]]

jstack 命令查看

相信你聽(tīng)說(shuō)過(guò)這玩意,jstack 命令就比較強(qiáng)大了,不僅能查看線程當(dāng)前狀態(tài),還能看調(diào)用棧,鎖等線程棧信息

大家可以隨意寫(xiě)一些程序,這里我用了上面 WAITING 狀態(tài)的代碼, 修改睡眠時(shí)間 Thread.sleep(100000),然后在終端按照下圖標(biāo)示依次執(zhí)行下圖命令 

更多功能還請(qǐng)大家自行查看,后續(xù)會(huì)單獨(dú)寫(xiě)文章來(lái)教大家如何使用jstack查看線程棧信息

Arthas

這個(gè)利器,無(wú)須多言吧,線上找茬監(jiān)控沒(méi)毛病,希望你可以靈活使用這個(gè)工具,攻克疑難雜癥

查看線程棧詳細(xì)信息,非常方便:https://alibaba.github.io/art...

相信你已經(jīng)和Arthas確認(rèn)了眼神

[[320332]]

關(guān)于線程生命周期狀態(tài)整體就算說(shuō)完了,編寫(xiě)并發(fā)程序時(shí)多問(wèn)一問(wèn)自己:

調(diào)用某個(gè)API會(huì)將你的線程置為甚么狀態(tài)?

多問(wèn)自己幾次,自然就記住上面的圖了

靈魂追問(wèn)

  1.  為什么調(diào)用 Thread.sleep, catch異常后,調(diào)用了Thread.currentThread().interrupt();
  2.  進(jìn)入 BLOCKED只有一種情況,就是等待 synchronized 監(jiān)視器鎖,那調(diào)用 JUC 中的 Lock.lock() 方法,如果某個(gè)線程等待這個(gè)鎖,這個(gè)線程狀態(tài)是什么呢?為什么?   
  1. public class ThreadStateTest {  
  2.        public static void main(String[] args) throws InterruptedException {  
  3.            TestLock testLock = new TestLock();  
  4.            Thread thread2 = new Thread(() -> {  
  5.                testLock.myTestLock();  
  6.            }, "thread2");  
  7.            Thread thread1 = new Thread(() -> {  
  8.                    testLock.myTestLock();  
  9.                }, "thread1");  
  10.            thread1.start();  
  11.            Thread.sleep(1000);  
  12.            thread2.start();  
  13.            Thread.sleep(1000);  
  14.            System.out.println("****" + (thread2.getState()));  
  15.            Thread.sleep(20000); 
  16.        }  
  17.    }  
  18.    @Slf4j  
  19.    class TestLock{  
  20.        private final Lock lock = new ReentrantLock();  
  21.        public void myTestLock(){  
  22.            lock.lock();  
  23.            try{  
  24.                Thread.sleep(10000);  
  25.                log.info("testLock status");  
  26.            } catch (InterruptedException e) {  
  27.                log.error(e.getMessage());  
  28.            } finally {  
  29.                lock.unlock();  
  30.            }  
  31.        }  
  32.    } 

      3.   synchronized 和 Lock 有什么區(qū)別?

參考

感謝前輩們總結(jié)的精華,自己所寫(xiě)的并發(fā)系列好多都參考了以下資料

  •  Java 并發(fā)編程實(shí)戰(zhàn)
  •  Java 并發(fā)編程之美
  •  碼出高效
  •  Java 并發(fā)編程的藝術(shù)
  •  ......

我這面也在逐步總結(jié)常見(jiàn)的并發(fā)面試問(wèn)題(總結(jié)ing......)答案整理好后會(huì)通知大家,請(qǐng)持續(xù)關(guān)注

 

 

責(zé)任編輯:龐桂玉 來(lái)源: segmentfault
相關(guān)推薦

2009-06-24 10:47:55

JSF生命周期

2022-04-19 07:20:24

軟件開(kāi)發(fā)安全生命周期SSDLC應(yīng)用安全

2010-07-14 10:48:37

Perl線程

2009-06-18 13:32:39

Java線程生命周期

2012-01-16 09:00:56

線程

2009-06-29 18:03:15

Java多線程線程的生命周期

2010-07-14 10:59:15

Perl線程

2023-10-26 08:25:35

Java線程周期

2015-07-08 16:28:23

weak生命周期

2021-08-24 07:53:28

AndroidActivity生命周期

2013-08-19 17:03:00

.Net生命周期對(duì)象

2021-07-19 05:52:29

網(wǎng)絡(luò)生命周期網(wǎng)絡(luò)框架

2012-06-20 10:29:16

敏捷開(kāi)發(fā)

2009-06-11 11:28:35

JSF生命周期

2023-10-07 00:05:07

2014-07-16 13:39:30

Windows Pho

2023-09-12 10:52:16

OpenSSL開(kāi)源套件

2011-06-16 09:31:21

ActivityAndroid

2012-04-28 13:23:12

Java類(lèi)生命周期

2013-08-01 09:40:51

Windows 8.1
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

亚洲一二区在线| 久久一区二区视频| 日本一区二区三区四区在线观看 | 亚洲91在线| 国产成人亚洲综合色影视| 波多野一区二区| 欧美一区二区三区四区在线观看| 色一情一乱一伦一区二区三区日本| 欧美蜜桃一区二区三区| 久久永久免费| 日韩啪啪电影网| 你懂的网址一区二区三区| 99国产精品久久久| 国产高清视频在线观看| 色噜噜狠狠色综合网图区| 女人天堂亚洲aⅴ在线观看| 欧美成人合集magnet| 午夜精品久久99蜜桃的功能介绍| 菠萝蜜视频在线观看入口| 午夜久久电影网| 欧美黄色网络| 免费在线成人av电影| 椎名由奈av一区二区三区| 女海盗2成人h版中文字幕| 国产精品亚洲美女av网站| 国产成人精品一区二区三区四区 | 精品三级av在线| 欧美三级情趣内衣| 精品久久久久av| 亚洲第一福利视频| 欧美激情日韩| 不卡日韩av| 国产精品私人影院| 国产v综合v| 视频在线一区二区三区| 色妞www精品视频| a√在线中文网新版址在线| 91超碰caoporn97人人| 风间由美性色一区二区三区| 在线视频观看国产| 波多野结衣成人在线| 一区二区三区欧美视频| 国产精品极品在线观看| 欧美 日韩 国产 高清| 精品偷拍各种wc美女嘘嘘| 欧美亚洲一区二区三区| 永久av在线| 国产91社区| 91国内精品野花午夜精品| 久久久久久久久国产一区| 色播在线观看| 国产精品吴梦梦| 亚洲国产欧美另类丝袜| 成人影视亚洲图片在线| 又黄又www的网站| 日本精品久久久久影院| 国产精品视频免费| 日韩精选在线| aaa免费看大片| 色婷婷激情综合| 男女视频在线| 国产精品一区二区三区免费观看| 一区二区三区欧美视频| 亚洲另类av| 2023欧美最顶级a∨艳星| 国产精品一区二区三区在线播放| 亚洲国产精品久久人人爱| 波多野结衣在线观看一区二区三区| 激情六月丁香| 91麻豆精品国产91久久久使用方法| 国产精品91一区二区三区| 在线国产福利网站| 国产精品揄拍一区二区| 精品久久在线播放| 好看的av在线不卡观看| 黄色免费网站在线| 中文字幕不卡每日更新1区2区| 精品不卡在线视频| 成人一区二区三区中文字幕| 日本午夜精品久久久久| 久久午夜夜伦鲁鲁一区二区| 青草青草久热精品视频在线网站 | 亚洲国产综合在线观看| 日韩伦理在线| 日韩av不卡播放| 精品国产乱码久久久久久牛牛 | 欧美性69xxxx肥| 欧美精品自拍| 大片免费在线观看| 中文字幕欧美日韩一区二区| 怡红院精品视频| 国产精品色哟哟网站| 在线看成人短视频| 你懂的视频在线| 日韩区国产区| 日韩中文字在线| 亚洲自拍偷拍九九九| 韩国av一区| 成年美女黄网站色大片不卡| 激情综合网俺也去| 91免费国产视频| 亚洲国产一区二区三区在线观看| 老司机精品视频网| 青青草av网站| 亚洲自拍小视频免费观看| 精品国产sm最大网站| 久久久久久综合| 五月激情久久久| 青春草在线视频| 男人用嘴添女人下身免费视频| 午夜精品福利在线观看| 一本久道中文字幕精品亚洲嫩| 天堂影院一区二区| 精品一区二区三区视频在线播放 | 久久麻豆一区二区| 日韩欧美在线中字| 激情网站在线| 9l视频白拍9色9l视频| 国产精品综合久久久久久| 国产午夜一区二区| 亚洲一区免费观看| 麻豆精品在线| 男女网站在线观看| www.一区二区.com| 国产精品午夜国产小视频| 亚洲精品福利在线观看| 综合中文字幕亚洲| 蜜桃视频第一区免费观看| 性欧美lx╳lx╳| 性欧美1819sex性高清大胸| 99热手机在线| 欧美久久在线| 欧美丰满少妇xxxxx| 欧美日韩大陆一区二区| 欧美高清在线精品一区| 三级精品在线观看| 久久成人高清| 日韩欧美少妇| 最新国产在线观看| 成人网18免费软件大全| 亚洲美女搞黄| 国产成人精品在线播放| 亚洲美女免费精品视频在线观看| 亚洲一区视频在线| 99精品一区二区| 久久精品人人做人人爽电影蜜月| 久久久久高潮毛片免费全部播放| 最近中文字幕免费mv2018在线 | 97精品久久久午夜一区二区三区| 黄色成人精品网站| 国产香蕉精品| 怡红院成人在线| 激情影院在线观看| 久久久久久久久久亚洲| 99久久久免费精品国产一区二区| 亚洲一区二区三区无吗| 91精品啪在线观看国产爱臀| 日本三级在线观看网站| 亚洲精选av在线| 日日碰狠狠添天天爽超碰97| 日韩免费av电影| 波多野结衣成人在线| 欧美专区在线观看| 欧美精品中文字幕一区| 亚洲全黄一级网站| 日韩欧美在线网站| 欧美亚洲免费在线一区| 亚洲一二三四在线| 国产精品乱人伦一区二区| av动漫一区二区| 国产精品主播直播| 日韩精品亚洲专区| 精品91久久久久| 亚洲一区二区| 国产精品久久久乱弄| 国产一区二区三区电影在线观看| 五月天最新网址| 少妇性l交大片| 久久国产午夜精品理论片最新版本| 日韩不卡av| 久久精品五月婷婷| 国产欧美日韩免费| 日本伊人精品一区二区三区介绍| 日韩在线视频网站| 正在播放亚洲1区| 亚洲女人被黑人巨大进入| 欧美成人一级视频| 日韩欧美视频一区| 欧美一级夜夜爽| 欧美久久久一区| 欧美亚一区二区| 欧美制服丝袜第一页| 色诱视频网站一区| 精品久久久久久久中文字幕| 亚洲一线二线三线久久久| 悠悠色在线精品| 亚洲另类春色国产| 亚洲1区2区3区4区| 色婷婷亚洲综合| 欧美一区二区三区在线观看|