日韩黑丝制服一区视频播放|日韩欧美人妻丝袜视频在线观看|九九影院一级蜜桃|亚洲中文在线导航|青草草视频在线观看|婷婷五月色伊人网站|日本一区二区在线|国产AV一二三四区毛片|正在播放久草视频|亚洲色图精品一区

分享

好程序員大數(shù)據(jù)教程之線(xiàn)程高級(jí)部分

 好程序員IT 2019-12-09

好程序員大數(shù)據(jù)教程之線(xiàn)程高級(jí)部分,首先講一下線(xiàn)程的生命周期

對(duì)于一個(gè)線(xiàn)程在被創(chuàng)建后不是立即就進(jìn)入到了運(yùn)行狀態(tài)也不是一直處于運(yùn)行狀態(tài)在線(xiàn)程的聲明周期中一個(gè)線(xiàn)程會(huì)在多種狀態(tài)之間進(jìn)行切換

>

>  

>

> new : 新生狀態(tài)線(xiàn)程被實(shí)例化但是還沒(méi)有開(kāi)始執(zhí)行(start)

>

> runnable: 就緒狀態(tài)已經(jīng)執(zhí)行過(guò)start, 線(xiàn)程已經(jīng)啟動(dòng)了只是沒(méi)有搶到CPU時(shí)間片

>

> running: 運(yùn)行狀態(tài)搶到了CPU時(shí)間片

>

> blocked: 阻塞狀態(tài)線(xiàn)程執(zhí)行的過(guò)程中遇到一些特殊情況會(huì)進(jìn)入阻塞狀態(tài)阻塞中的線(xiàn)程是不能參數(shù)時(shí)間片的搶奪的 (不能被線(xiàn)程調(diào)度器調(diào)度)

>

> dead: 死亡狀態(tài)線(xiàn)程終止

>

 正常死亡 : run方法中的代碼執(zhí)行結(jié)束

>

 非正常死亡 : 強(qiáng)制使用stop方法停止這個(gè)線(xiàn)程



#### 臨界資源問(wèn)題

由于線(xiàn)程之間是資源共享的。如果有多個(gè)線(xiàn)程,同時(shí)對(duì)一個(gè)數(shù)據(jù)進(jìn)行操作,此時(shí)這個(gè)數(shù)據(jù)會(huì)出現(xiàn)問(wèn)題。

如果有一個(gè)線(xiàn)程在訪問(wèn)一個(gè)臨界資源,在訪問(wèn)之前,先對(duì)這個(gè)資源“上鎖”,此時(shí)如果有其他的線(xiàn)程也需要訪問(wèn)這個(gè)臨界資源,需要先查這個(gè)資源有沒(méi)有被上鎖,如果沒(méi)有被上鎖,此時(shí)這個(gè)線(xiàn)程可以訪問(wèn)這個(gè)資源;如果上鎖了,則此時(shí)這個(gè)線(xiàn)程進(jìn)入阻塞狀態(tài),等待解鎖。

####同步代碼段

> ```java

> // 同步代碼段

> // 小括號(hào):就是鎖

> // 大括號(hào):同步代碼段,一般情況下,寫(xiě)需要對(duì)臨界資源進(jìn)行的操作

> synchronized () {

>   

> }

> // 關(guān)于同步鎖:可以分成兩種:對(duì)象鎖、類(lèi)鎖

> // 

> ```

>

####同步方法

> ```java

> // 使用synchronized關(guān)鍵字修飾的方法就是同步方法

> // 將一個(gè)方法中所有的代碼進(jìn)行一個(gè)同步

> // 相當(dāng)于將一個(gè)方法中所有的代碼都放到一個(gè)synchronized代碼段中

> // 同步方法的鎖:

> // 1. 如果這個(gè)方法是一個(gè)非靜態(tài)方法:鎖是this

> // 2. 如果這個(gè)方法是一個(gè)靜態(tài)方法:鎖是類(lèi)鎖(當(dāng)前類(lèi).class

> private synchronized void sellTicket() {

> }

> ```

>

#### lockunlock

就是一個(gè)類(lèi)RenntrantLock

#### 線(xiàn)程死鎖(了解)

在解決臨界資源問(wèn)題的時(shí)候,我們引入了一個(gè)""的概念。我們可以用鎖對(duì)一個(gè)資源進(jìn)行保護(hù)。實(shí)際,在多線(xiàn)程的環(huán)境下,有可能會(huì)出現(xiàn)一種情況:

假設(shè)有AB兩個(gè)線(xiàn)程,其中線(xiàn)程A持有鎖標(biāo)記a,線(xiàn)程B持有鎖標(biāo)記b,而此時(shí),線(xiàn)程A等待鎖標(biāo)記b的釋放,線(xiàn)程B等待鎖標(biāo)記a的釋放。這種情況,叫做  **死鎖**

#### 生產(chǎn)者消費(fèi)者設(shè)計(jì)模式

> wait() 、notify() notifyAll()

>

> wait(): 等待。使得當(dāng)前的線(xiàn)程釋放鎖標(biāo)記,進(jìn)入等待隊(duì)列。可以使當(dāng)前的線(xiàn)程進(jìn)入阻塞狀態(tài)。

>

> notify(): 喚醒,喚醒等待隊(duì)列中的一個(gè)線(xiàn)程。

>

> notifyAll(): 喚醒,喚醒等待隊(duì)列中所有的線(xiàn)程。

> waitsleep的區(qū)別:

>

> 1. 兩個(gè)方法都可以使一個(gè)線(xiàn)程進(jìn)入阻塞。

> 2. 區(qū)別:wait方法會(huì)釋放鎖標(biāo)記,sleep則不會(huì)釋放鎖標(biāo)記。

####懶漢式單例設(shè)計(jì)模式中的線(xiàn)程安全問(wèn)題

#### 線(xiàn)程池

> ThreadPoolExecutor類(lèi)是線(xiàn)程池最核心的類(lèi)。這個(gè)類(lèi)的構(gòu)造方法中的幾個(gè)參數(shù):

>

> int corePoolSize: 核心線(xiàn)程數(shù)量。核心池大小。

>

> int maxmiunPoolSize: 線(xiàn)程池中最多的線(xiàn)程數(shù)量。

>

> long keepAliveTime: 核心線(xiàn)程之外的臨時(shí)線(xiàn)程,能存活的時(shí)間。(從這個(gè)線(xiàn)程空閑的時(shí)候開(kāi)始算)

>

> TimeUnit unit: 上面的時(shí)間單位

>

 NANOSECONDS: 納秒

>

 MICROSECONDS: 微秒

>

 MILLISEONDS: 毫秒

>

 SECONDS: 

>

 MINUTES: 

>

 HOURS: 時(shí)

>

 DAYS: 

>

> BlockingQueue<Runnable> workQueue: 等待隊(duì)列

>

 ArrayBlockingQueue

>

 LinkedBlockingQueue

>

  SynchronousQueue

>

> RejectedExecutionHandler handler:拒絕訪問(wèn)策略

預(yù)習(xí)方向:

1. 網(wǎng)絡(luò)編程

2. TCP

3. UDP

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶(hù)發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買(mǎi)等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶(hù) 評(píng)論公約

    類(lèi)似文章 更多