一区二区三区精品视频-一区二区三区国产美女在线播放-一区二区三区福利视频-一区二区三区福利-毛片大全免费看-毛片大片免费看

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

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

什么時候用多線程?什么時候用多進程?

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

  1)需要頻繁創(chuàng)建銷毀的優(yōu)先用線程 原因請看上面的對比。 這種原則最常見的應(yīng)用就是Web服務(wù)器了,來一個連接建立一個線程,斷了就銷毀線程,要是用進程,創(chuàng)建和銷毀的代價是很難承受的

  2)需要進行大量計算的優(yōu)先使用線程 所謂大量計算,當然就是要耗費很多CPU,切換頻繁了,這種情況下線程是最合適的。 這種原則最常見的是圖像處理、算法處理。

  3)強相關(guān)的處理用線程,弱相關(guān)的處理用進程

什么時候用多線程

  什么叫強相關(guān)、弱相關(guān)?

  理論上很難定義,給個簡單的例子就明白了。

  一般的Server需要完成如下任務(wù):消息收發(fā)、消息處理。“消息收發(fā)”和“消息處理”就是弱相關(guān)的任務(wù),而“消息處理”里面可能又分為“消息解碼”、“業(yè)務(wù)處理”,這兩個任務(wù)相對來說相關(guān)性就要強多了。因此“消息收發(fā)”和“消息處理”可以分進程設(shè)計,“消息解碼”、“業(yè)務(wù)處理”可以分線程設(shè)計。

  當然這種劃分方式不是一成不變的,也可以根據(jù)實際情況進行調(diào)整。

  4)可能要擴展到多機分布的用進程,多核分布的用線程原因請看上面對比。

  5)都滿足需求的情況下,用你最熟悉、最拿手的方式 至于“數(shù)據(jù)共享、同步”、“編程、調(diào)試”、“可靠性”這幾個維度的所謂的“復雜、簡單”應(yīng)該怎么取舍,我只能說:沒有明確的選擇方法。

  但我可以告訴你一個選擇原則:如果多進程和多線程都能夠滿足要求,那么選擇你最熟悉、最拿手的那個。

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

學習資源站

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

相關(guān)推薦

  • 物聯(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)勢包括:低延遲:通過
  • 什么是物聯(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)的核心原理包括:感知和采集:通過傳感器和
  • 談?wù)劸W(wǎng)絡(luò)的分層結(jié)構(gòu) 1. 物理層:不是指具體的物理設(shè)備 指的是物理設(shè)備的標準制定 (網(wǎng)線 光纖的接口類型 網(wǎng)卡的電流強弱)比特流 2. 數(shù)據(jù)鏈路層:負責完整的幀數(shù)據(jù)收發(fā) (幀數(shù)據(jù)可以獨立在網(wǎng)絡(luò)傳輸?shù)臄?shù)據(jù)) mac地址封裝和解封裝,交換器就工作在這一層
  • git和GitHub關(guān)系 它是一個用于 Linux內(nèi)核開發(fā)的版本管理工具,是可以在你電腦不聯(lián)網(wǎng)的情況下,只在本地使用的一個版本管理工具,其作用就是可以讓你更好的管理你的程序,比如你原來提交過的內(nèi)容,以后雖然修改了,但是通過git這個工具,可以把你原來提交的內(nèi)容重現(xiàn)出來,這樣對于你后來才意識到的一些錯誤的更改,可以進行還原。
  • 多線程開發(fā)帶來的問題與解決方法? 線程安全問題指的是在某一線程從開始訪問到結(jié)束訪問某一數(shù)據(jù)期間,該數(shù)據(jù)被其他的線程所修改,那么對于當前線程而言,該線程就發(fā)生了線程安全問題,表現(xiàn)形式為數(shù)據(jù)的缺失,數(shù)據(jù)不一致等。
  • sleep()方法和wait()方法區(qū)別和共同點? - sleep()方法屬于Thread類的靜態(tài)方法,作用于當前線程;而wait()方法是Object類的實例方法,作用于對象本身。 - 執(zhí)行sleep()方法后,可以通過超時或者調(diào)用interrupt()方法喚醒休眠中的線程;執(zhí)行wait()方法后,通過調(diào)用notify()或notifyAll()方法喚醒等待線程。
  • 主站蜘蛛池模板: 阿克苏市| 潼南县| 六盘水市| 萨迦县| 南宁市| 舞阳县| 桃江县| 龙山县| 磐安县| 佛学| 湾仔区| 阿拉善左旗| 陆丰市| 左权县| 田林县| 台南县| 莒南县| 南宁市| 登封市| 肥乡县| 崇文区| 山阳县| 华池县| 乐安县| 南投市| 大余县| 临西县| 东山县| 噶尔县| 阿鲁科尔沁旗| 上虞市| 汶上县| 丰顺县| 福州市| 沙洋县| 友谊县| 万源市| 大同市| 正阳县| 沅陵县| 三原县|