千鋒教育-做有情懷、有良心、有品質的職業教育機構

當前位置:首頁  >  IT面試題  >  物聯網面試題  >  正文

多線程開發帶來的問題與解決方法?

來源:千鋒教育
發布時間:2022-09-26 14:09:00
分享

  使用多線程主要會帶來以下幾個問題:

  一、線程安全問題

  線程安全問題指的是在某一線程從開始訪問到結束訪問某一數據期間,該數據被其他的線程所修改,那么對于當前線程而言,該線程就發生了線程安全問題,表現形式為數據的缺失,數據不一致等。

  線程安全問題發生的條件:

  1)多線程環境下,即存在包括自己在內存在有多個線程。

  2)多線程環境下存在共享資源,且多線程操作該共享資源。

  3)多個線程必須對該共享資源有非原子性操作。

  線程安全問題的解決思路:

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

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

  3)使用ThreadLocal為每一個線程建立一個變量的副本,各個線程間獨立操作,互不影響。

多線程開發帶來的問題與解決方法?

  二、性能問題

  線程的生命周期開銷是非常大的,一個線程的創建到銷毀都會占用大量的內存。同時如果不合理的創建了多個線程,cup的處理器數量小于了線程數量,那么將會有很多的線程被閑置,閑置的線程將會占用大量的內存,為垃圾回收帶來很大壓力,同時cup在分配線程時還會消耗其性能。

  解決思路:

  利用線程池,模擬一個池,預先創建有限合理個數的線程放入池中,當需要執行任務時從池中取出空閑的先去執行任務,執行完成后將線程歸還到池中,這樣就減少了線程的頻繁創建和銷毀,節省內存開銷和減小了垃圾回收的壓力。同時因為任務到來時本身線程已經存在,減少了創建線程時間,提高了執行效率,而且合理的創建線程池數量還會使各個線程都處于忙碌狀態,提高任務執行效率,線程池還提供了拒絕策略,當任務數量到達某一臨界區時,線程池將拒絕任務的進入,保持現有任務的順利執行,減少池的壓力。

  三、活躍性問題

  1)死鎖

  假如線程 A 持有資源 2,線程 B 持有資源 1,他們同時都想申請對方的資源,所以這兩個線程就會互相等待而進入死鎖狀態。多個線程環形占用資源也是一樣的會產生死鎖問題。

  解決方法:

  - 避免一個線程同時獲取多個鎖

  - 避免一個線程在鎖內同時占用多個資源,盡量保證每個鎖只占用一個資源。

  - 嘗試使用定時鎖,使用 lock.tryLock(timeout) 來代替使用內部鎖機制。 想要避免死鎖,可以使用無鎖函數(cas)或者使用重入鎖(ReentrantLock),通過重入鎖使線程中斷或限時等待可以有效的規避死鎖問題。

  2)饑餓

  饑餓指的是某一線程或多個線程因為某些原因一直獲取不到資源,導致程序一直無法執行。如某一線程優先級太低導致一直分配不到資源,或者是某一線程一直占著某種資源不放,導致該線程無法執行等。

  解決方法:

  與死鎖相比,饑餓現象還是有可能在一段時間之后恢復執行的。可以設置合適的線程優先級來盡量避免饑餓的產生。

  3)活鎖

  活鎖體現了一種謙讓的美德,每個線程都想把資源讓給對方,但是由于機器“智商”不夠,可能會產生一直將資源讓來讓去,導致資源在兩個線程間跳動而無法使某一線程真正的到資源并執行,這就是活鎖的問題。

  四、阻塞

  阻塞是用來形容多線程的問題,幾個線程之間共享臨界區資源,那么當一個線程占用了臨界區資源后,所有需要使用該資源的線程都需要進入該臨界區等待,等待會導致線程掛起,一直不能工作,這種情況就是阻塞,如果某一線程一直都不釋放資源,將會導致其他所有等待在這個臨界區的線程都不能工作。

  當我們使用synchronized或重入鎖時,我們得到的就是阻塞線程,如論是synchronized或者重入鎖,都會在試圖執行代碼前,得到臨界區的鎖,如果得不到鎖,線程將會被掛起等待,知道其他線程執行完成并釋放鎖且拿到鎖為止。

  解決方法:

  可以通過減少鎖持有時間,讀寫鎖分離,減小鎖的粒度,鎖分離,鎖粗化等方式來優化鎖的性能。

  臨界區: 臨界區是用來表示一種公共的資源(共享數據),它可以被多個線程使用,但是在每次只能有一個線程能夠使用它,當臨界區資源正在被一個線程使用時,其他的線程就只能等待當前線程執行完之后才能使用該臨界區資源。

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

聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。

相關推薦

  • 物聯網中的邊緣計算是什么?請解釋其優勢和應用場景 答案:邊緣計算是一種將計算和數據處理能力移動到物聯網設備附近的計算模型。在邊緣計算中,數據的處理和分析發生在接近數據源的設備或邊緣節點上,而不是傳輸到遠程云端進行處理。邊緣計算的優勢包括:低延遲:通過
  • 什么是物聯網(IoT)?請解釋其核心原理和應用領域 答案:物聯網是指通過互聯網連接和交互的物理設備網絡。它基于傳感器、嵌入式系統、無線通信技術等,將各種物理設備連接起來,實現設備之間的數據交換和智能化控制。物聯網的核心原理包括:感知和采集:通過傳感器和
  • 談談網絡的分層結構 1. 物理層:不是指具體的物理設備 指的是物理設備的標準制定 (網線 光纖的接口類型 網卡的電流強弱)比特流 2. 數據鏈路層:負責完整的幀數據收發 (幀數據可以獨立在網絡傳輸的數據) mac地址封裝和解封裝,交換器就工作在這一層
  • git和GitHub關系 它是一個用于 Linux內核開發的版本管理工具,是可以在你電腦不聯網的情況下,只在本地使用的一個版本管理工具,其作用就是可以讓你更好的管理你的程序,比如你原來提交過的內容,以后雖然修改了,但是通過git這個工具,可以把你原來提交的內容重現出來,這樣對于你后來才意識到的一些錯誤的更改,可以進行還原。
  • 多線程開發帶來的問題與解決方法? 線程安全問題指的是在某一線程從開始訪問到結束訪問某一數據期間,該數據被其他的線程所修改,那么對于當前線程而言,該線程就發生了線程安全問題,表現形式為數據的缺失,數據不一致等。
  • sleep()方法和wait()方法區別和共同點? - sleep()方法屬于Thread類的靜態方法,作用于當前線程;而wait()方法是Object類的實例方法,作用于對象本身。 - 執行sleep()方法后,可以通過超時或者調用interrupt()方法喚醒休眠中的線程;執行wait()方法后,通過調用notify()或notifyAll()方法喚醒等待線程。
  • 主站蜘蛛池模板: 国产suv精品一区二区6| 怡红院一区二区三区| 无码人妻一区二区三区在线水卜樱 | 久久精品一区二区| 亚洲av乱码一区二区三区香蕉| 国产亚洲福利精品一区| 久久青青草原一区二区| 午夜影视日本亚洲欧洲精品一区| 一区二区中文字幕| 亚洲福利电影一区二区?| 亚洲av乱码一区二区三区| 中文字幕一精品亚洲无线一区| 日韩精品一区二区三区老鸦窝| 一区二区免费视频| 久久中文字幕一区二区| 亚洲国产精品一区第二页 | 97久久精品无码一区二区| 日本伊人精品一区二区三区| 国产亚洲无线码一区二区 | 日本一区二区三区免费高清在线| 国产午夜精品片一区二区三区| 色噜噜狠狠一区二区三区果冻| 一区二区三区在线|欧| 亚洲一区在线观看视频| 亚洲一区二区三区高清不卡| 成人免费观看一区二区| 丝袜美腿一区二区三区| 狠狠色综合一区二区| 中文字幕日韩精品一区二区三区 | 少妇人妻偷人精品一区二区| 精品亚洲A∨无码一区二区三区| 亚洲色欲一区二区三区在线观看| 国产一区二区精品久久岳√| 久久精品免费一区二区| 精品一区二区三区免费观看| 午夜DV内射一区区| 中文字幕在线无码一区| 国产在线aaa片一区二区99| 无码AⅤ精品一区二区三区| 精品视频一区在线观看| 国产成人无码精品一区在线观看|