偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

多線(xiàn)程開(kāi)發(fā)帶來(lái)的問(wèn)題與解決方法

開(kāi)發(fā) 前端
臨界區(qū)是用來(lái)表示一種公共的資源(共享數(shù)據(jù)),它可以被多個(gè)線(xiàn)程使用,但是在每次只能有一個(gè)線(xiàn)程能夠使用它,當(dāng)臨界區(qū)資源正在被一個(gè)線(xiàn)程使用時(shí),其他的線(xiàn)程就只能等待當(dāng)前線(xiàn)程執(zhí)行完之后才能使用該臨界區(qū)資源。

使用多線(xiàn)程主要會(huì)帶來(lái)以下幾個(gè)問(wèn)題:

(一)線(xiàn)程安全問(wèn)題

  線(xiàn)程安全問(wèn)題指的是在某一線(xiàn)程從開(kāi)始訪(fǎng)問(wèn)到結(jié)束訪(fǎng)問(wèn)某一數(shù)據(jù)期間,該數(shù)據(jù)被其他的線(xiàn)程所修改,那么對(duì)于當(dāng)前線(xiàn)程而言,該線(xiàn)程就發(fā)生了線(xiàn)程安全問(wèn)題,表現(xiàn)形式為數(shù)據(jù)的缺失,數(shù)據(jù)不一致等。

  線(xiàn)程安全問(wèn)題發(fā)生的條件:

    1)多線(xiàn)程環(huán)境下,即存在包括自己在內(nèi)存在有多個(gè)線(xiàn)程。

    2)多線(xiàn)程環(huán)境下存在共享資源,且多線(xiàn)程操作該共享資源。

    3)多個(gè)線(xiàn)程必須對(duì)該共享資源有非原子性操作。

  線(xiàn)程安全問(wèn)題的解決思路:

    1)盡量不使用共享變量,將不必要的共享變量變成局部變量來(lái)使用。

    2)使用synchronized關(guān)鍵字同步代碼塊,或者使用jdk包中提供的Lock為操作進(jìn)行加鎖。

    3)使用ThreadLocal為每一個(gè)線(xiàn)程建立一個(gè)變量的副本,各個(gè)線(xiàn)程間獨(dú)立操作,互不影響。

(二)性能問(wèn)題

  線(xiàn)程的生命周期開(kāi)銷(xiāo)是非常大的,一個(gè)線(xiàn)程的創(chuàng)建到銷(xiāo)毀都會(huì)占用大量的內(nèi)存。同時(shí)如果不合理的創(chuàng)建了多個(gè)線(xiàn)程,cup的處理器數(shù)量小于了線(xiàn)程數(shù)量,那么將會(huì)有很多的線(xiàn)程被閑置,閑置的線(xiàn)程將會(huì)占用大量的內(nèi)存,為垃圾回收帶來(lái)很大壓力,同時(shí)cup在分配線(xiàn)程時(shí)還會(huì)消耗其性能。

  解決思路:

  利用線(xiàn)程池,模擬一個(gè)池,預(yù)先創(chuàng)建有限合理個(gè)數(shù)的線(xiàn)程放入池中,當(dāng)需要執(zhí)行任務(wù)時(shí)從池中取出空閑的先去執(zhí)行任務(wù),執(zhí)行完成后將線(xiàn)程歸還到池中,這樣就減少了線(xiàn)程的頻繁創(chuàng)建和銷(xiāo)毀,節(jié)省內(nèi)存開(kāi)銷(xiāo)和減小了垃圾回收的壓力。同時(shí)因?yàn)槿蝿?wù)到來(lái)時(shí)本身線(xiàn)程已經(jīng)存在,減少了創(chuàng)建線(xiàn)程時(shí)間,提高了執(zhí)行效率,而且合理的創(chuàng)建線(xiàn)程池?cái)?shù)量還會(huì)使各個(gè)線(xiàn)程都處于忙碌狀態(tài),提高任務(wù)執(zhí)行效率,線(xiàn)程池還提供了拒絕策略,當(dāng)任務(wù)數(shù)量到達(dá)某一臨界區(qū)時(shí),線(xiàn)程池將拒絕任務(wù)的進(jìn)入,保持現(xiàn)有任務(wù)的順利執(zhí)行,減少池的壓力。

(三)活躍性問(wèn)題

  1)死鎖,假如線(xiàn)程 A 持有資源 2,線(xiàn)程 B 持有資源 1,他們同時(shí)都想申請(qǐng)對(duì)方的資源,所以這兩個(gè)線(xiàn)程就會(huì)互相等待而進(jìn)入死鎖狀態(tài)。多個(gè)線(xiàn)程環(huán)形占用資源也是一樣的會(huì)產(chǎn)生死鎖問(wèn)題。

  解決方法:

  • 避免一個(gè)線(xiàn)程同時(shí)獲取多個(gè)鎖
  • 避免一個(gè)線(xiàn)程在鎖內(nèi)同時(shí)占用多個(gè)資源,盡量保證每個(gè)鎖只占用一個(gè)資源。
  • 嘗試使用定時(shí)鎖,使用 lock.tryLock(timeout) 來(lái)代替使用內(nèi)部鎖機(jī)制。

  想要避免死鎖,可以使用無(wú)鎖函數(shù)(cas)或者使用重入鎖(ReentrantLock),通過(guò)重入鎖使線(xiàn)程中斷或限時(shí)等待可以有效的規(guī)避死鎖問(wèn)題。

  2)饑餓,饑餓指的是某一線(xiàn)程或多個(gè)線(xiàn)程因?yàn)槟承┰蛞恢鲍@取不到資源,導(dǎo)致程序一直無(wú)法執(zhí)行。如某一線(xiàn)程優(yōu)先級(jí)太低導(dǎo)致一直分配不到資源,或者是某一線(xiàn)程一直占著某種資源不放,導(dǎo)致該線(xiàn)程無(wú)法執(zhí)行等。

  解決方法:

  與死鎖相比,饑餓現(xiàn)象還是有可能在一段時(shí)間之后恢復(fù)執(zhí)行的。可以設(shè)置合適的線(xiàn)程優(yōu)先級(jí)來(lái)盡量避免饑餓的產(chǎn)生。

  3)活鎖,活鎖體現(xiàn)了一種謙讓的美德,每個(gè)線(xiàn)程都想把資源讓給對(duì)方,但是由于機(jī)器“智商”不夠,可能會(huì)產(chǎn)生一直將資源讓來(lái)讓去,導(dǎo)致資源在兩個(gè)線(xiàn)程間跳動(dòng)而無(wú)法使某一線(xiàn)程真正的到資源并執(zhí)行,這就是活鎖的問(wèn)題。

(四)阻塞

  阻塞是用來(lái)形容多線(xiàn)程的問(wèn)題,幾個(gè)線(xiàn)程之間共享臨界區(qū)資源,那么當(dāng)一個(gè)線(xiàn)程占用了臨界區(qū)資源后,所有需要使用該資源的線(xiàn)程都需要進(jìn)入該臨界區(qū)等待,等待會(huì)導(dǎo)致線(xiàn)程掛起,一直不能工作,這種情況就是阻塞,如果某一線(xiàn)程一直都不釋放資源,將會(huì)導(dǎo)致其他所有等待在這個(gè)臨界區(qū)的線(xiàn)程都不能工作。當(dāng)我們使用synchronized或重入鎖時(shí),我們得到的就是阻塞線(xiàn)程,如論是synchronized或者重入鎖,都會(huì)在試圖執(zhí)行代碼前,得到臨界區(qū)的鎖,如果得不到鎖,線(xiàn)程將會(huì)被掛起等待,知道其他線(xiàn)程執(zhí)行完成并釋放鎖且拿到鎖為止。

  解決方法:

  可以通過(guò)減少鎖持有時(shí)間,讀寫(xiě)鎖分離,減小鎖的粒度,鎖分離,鎖粗化等方式來(lái)優(yōu)化鎖的性能。

臨界區(qū):

  臨界區(qū)是用來(lái)表示一種公共的資源(共享數(shù)據(jù)),它可以被多個(gè)線(xiàn)程使用,但是在每次只能有一個(gè)線(xiàn)程能夠使用它,當(dāng)臨界區(qū)資源正在被一個(gè)線(xiàn)程使用時(shí),其他的線(xiàn)程就只能等待當(dāng)前線(xiàn)程執(zhí)行完之后才能使用該臨界區(qū)資源。

  比如辦公室辦公室里有一支筆,它一次只能被一個(gè)人使用,假如它正在被甲使用時(shí),其他想要使用這支筆的人只能等甲使用完這支筆之后才能允許另一個(gè)人去使用。這就是臨界區(qū)的概念。

責(zé)任編輯:武曉燕 來(lái)源: java知路
相關(guān)推薦

2022-04-02 20:27:30

ETS操作系統(tǒng)鴻蒙

2009-07-03 18:14:27

Servlet線(xiàn)程安全

2009-07-09 17:14:11

Incompatibl

2009-09-10 09:35:25

Linq語(yǔ)句

2025-04-30 08:14:30

2023-06-29 08:18:27

Java顯示鎖顯示條件隊(duì)列

2010-02-23 13:07:07

CentOS gcc

2019-01-18 09:42:39

2019-09-26 10:19:27

設(shè)計(jì)電腦Java

2009-06-12 11:06:56

Java heap s

2009-07-01 18:14:36

JSP亂碼

2010-08-31 13:56:38

PHP5多線(xiàn)程

2011-05-03 14:57:00

網(wǎng)絡(luò)打印機(jī)常見(jiàn)問(wèn)題解決方案

2023-10-26 08:16:20

C++線(xiàn)程

2009-02-26 11:13:41

Weblogic中間件JSP

2010-10-15 11:22:24

MySQL復(fù)制表結(jié)構(gòu)

2011-05-06 17:25:58

硒鼓

2009-09-22 17:21:24

線(xiàn)程局部變量

2009-07-24 10:42:28

CLR線(xiàn)程池

2013-04-16 09:46:44

點(diǎn)贊
收藏

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