• <label id="nxzaf"><del id="nxzaf"></del></label>

        <fieldset id="nxzaf"><em id="nxzaf"></em></fieldset>
        <label id="nxzaf"></label>
        <span id="nxzaf"><optgroup id="nxzaf"></optgroup></span>
      1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

        當(dāng)前位置:首頁  >  IT面試題  >  物聯(lián)網(wǎng)面試題  >  正文

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

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

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

          一、線程安全問題

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

          線程安全問題發(fā)生的條件:

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

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

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

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

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

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

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

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

          二、性能問題

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

          解決思路:

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

          三、活躍性問題

          1)死鎖

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

          解決方法:

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

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

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

          2)饑餓

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

          解決方法:

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

          3)活鎖

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

          四、阻塞

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

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

          解決方法:

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

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

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

        聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。

        學(xué)習(xí)資源站

        • 免費全套視頻教程
        • 企業(yè)實戰(zhàn)項目源碼
        • 大廠筆試真題題庫
        • 行業(yè)前瞻發(fā)展趨勢

        相關(guān)推薦

      2. 物聯(lián)網(wǎng)中的邊緣計算是什么?請解釋其優(yōu)勢和應(yīng)用場景 答案:邊緣計算是一種將計算和數(shù)據(jù)處理能力移動到物聯(lián)網(wǎng)設(shè)備附近的計算模型。在邊緣計算中,數(shù)據(jù)的處理和分析發(fā)生在接近數(shù)據(jù)源的設(shè)備或邊緣節(jié)點上,而不是傳輸?shù)竭h程云端進行處理。邊緣計算的優(yōu)勢包括:低延遲:通過
      3. 什么是物聯(lián)網(wǎng)(IoT)?請解釋其核心原理和應(yīng)用領(lǐng)域 答案:物聯(lián)網(wǎng)是指通過互聯(lián)網(wǎng)連接和交互的物理設(shè)備網(wǎng)絡(luò)。它基于傳感器、嵌入式系統(tǒng)、無線通信技術(shù)等,將各種物理設(shè)備連接起來,實現(xiàn)設(shè)備之間的數(shù)據(jù)交換和智能化控制。物聯(lián)網(wǎng)的核心原理包括:感知和采集:通過傳感器和
      4. 談?wù)劸W(wǎng)絡(luò)的分層結(jié)構(gòu) 1. 物理層:不是指具體的物理設(shè)備 指的是物理設(shè)備的標(biāo)準(zhǔn)制定 (網(wǎng)線 光纖的接口類型 網(wǎng)卡的電流強弱)比特流 2. 數(shù)據(jù)鏈路層:負(fù)責(zé)完整的幀數(shù)據(jù)收發(fā) (幀數(shù)據(jù)可以獨立在網(wǎng)絡(luò)傳輸?shù)臄?shù)據(jù)) mac地址封裝和解封裝,交換器就工作在這一層
      5. git和GitHub關(guān)系 它是一個用于 Linux內(nèi)核開發(fā)的版本管理工具,是可以在你電腦不聯(lián)網(wǎng)的情況下,只在本地使用的一個版本管理工具,其作用就是可以讓你更好的管理你的程序,比如你原來提交過的內(nèi)容,以后雖然修改了,但是通過git這個工具,可以把你原來提交的內(nèi)容重現(xiàn)出來,這樣對于你后來才意識到的一些錯誤的更改,可以進行還原。
      6. 多線程開發(fā)帶來的問題與解決方法? 線程安全問題指的是在某一線程從開始訪問到結(jié)束訪問某一數(shù)據(jù)期間,該數(shù)據(jù)被其他的線程所修改,那么對于當(dāng)前線程而言,該線程就發(fā)生了線程安全問題,表現(xiàn)形式為數(shù)據(jù)的缺失,數(shù)據(jù)不一致等。
      7. sleep()方法和wait()方法區(qū)別和共同點? - sleep()方法屬于Thread類的靜態(tài)方法,作用于當(dāng)前線程;而wait()方法是Object類的實例方法,作用于對象本身。 - 執(zhí)行sleep()方法后,可以通過超時或者調(diào)用interrupt()方法喚醒休眠中的線程;執(zhí)行wait()方法后,通過調(diào)用notify()或notifyAll()方法喚醒等待線程。
      8. 主站蜘蛛池模板: 99久久精品国产一区二区蜜芽| 一本一本久久a久久精品综合麻豆| 国产精品成人99久久久久91gav| 91精品国产乱码久久久久久| 麻豆国产精品VA在线观看不卡| 国产精品亚洲mnbav网站| 99久久人人爽亚洲精品美女| 一区二区三区精品高清视频免费在线播放| 国产成人精品福利网站在线| 91老司机深夜福利精品视频在线观看| 国产精品成人久久久久久久| 国产欧美一区二区精品性色99| 中文字幕精品亚洲无线码一区应用| 97精品在线播放| 美女岳肉太深了使劲国产精品亚洲专一区二区三区| 国产精品 猎奇 另类视频| 国产精品xxxx国产喷水亚洲国产精品无码久久一区| 精品人妻中文字幕有码在线| 99R在线精品视频在线播放| 91国内揄拍国内精品对白不卡| 精品久久久无码中文字幕| 欧美精品91欧美日韩操| 日韩精品无码熟人妻视频| 欧美亚洲另类精品第一页| 51国偷自产精品一区在线视频| segui久久国产精品| 无码人妻精品一区二区三区久久久| 人人妻人人澡人人爽精品欧美| 欧美精品免费观看二区| 精品人妻无码专区中文字幕| 国产精品爽黄69天堂a| 国产叼嘿久久精品久久| 野狼第一精品社区| 精品麻豆丝袜高跟鞋AV| 国产精品免费久久久久影院| 四虎4hu永久免费国产精品| 国产精品一二二区| 久久精品国产网红主播| 国产精品亚洲专区在线观看| 亚洲精品国产精品乱码不卞| 欧美精品一区二区蜜臀亚洲|