java開發(fā)中常見中間件 八核十六線程的Cpu有哪些不會性能過剩的應(yīng)用場景?
八核十六線程的Cpu有哪些不會性能過剩的應(yīng)用場景?一個非常重要的因素與操作系統(tǒng)和平臺有關(guān)。有一個很好的例子。在windows平臺上,由于效率問題和缺乏并行計算方案,8核16線程在大多數(shù)情況下可能是無用
八核十六線程的Cpu有哪些不會性能過剩的應(yīng)用場景?
一個非常重要的因素與操作系統(tǒng)和平臺有關(guān)。有一個很好的例子。
在windows平臺上,由于效率問題和缺乏并行計算方案,8核16線程在大多數(shù)情況下可能是無用的。
但是在Linux平臺上是不一樣的,幾乎所有的科學計算或仿真軟件都是基于Linux平臺的,這種幾十萬的CPU使用太普遍了。
例如,目前所有的芯片設(shè)計軟件都是在Linux平臺上進行的,特別是先進技術(shù)(如7Nm)的設(shè)計極其復雜,設(shè)計規(guī)模巨大(100億設(shè)備規(guī)模)。使用幾十個或幾百個cpu和簡單線程運行模擬是很常見的。
所以學習一個并行計算工具或模擬軟件,你會發(fā)現(xiàn)8核16線程有時是不夠的
Java語言的一個重要特點是支持多線程。多線程技術(shù)是Java的一種先進技術(shù),它涉及到操作系統(tǒng)的知識,接近于系統(tǒng)級。對于普通程序員來說,他們很少碰它。目前,在javaee(原始J2EE)的相關(guān)框架中,盡量避免使用線程。程序員最理想的狀態(tài)是專注于業(yè)務(wù)邏輯,而不是每天思考如何編寫線程。最典型的應(yīng)用程序,如tomcat、tomcat,是多線程的,數(shù)百個客戶機訪問同一個web應(yīng)用程序。在Tomcat訪問之后,隨后的處理被拋出到一個新線程。新線程最終被調(diào)用到我們的servlet程序,比如doGet或doPost。
如果我們不使用多線程機制,當數(shù)百人同時訪問一個web應(yīng)用程序時,Tomcat將不得不排隊等待串行處理,因此客戶端根本無法忍受這種訪問速度。
還需要異步處理,您需要使用多線程。例如,任務(wù)a和任務(wù)B需要并行處理,單個線程只能串行處理。首先完成任務(wù)a,然后執(zhí)行任務(wù)B,如果要同時執(zhí)行多個任務(wù),必須為每個任務(wù)分配一個線程,然后通過Java虛擬機的線程調(diào)度,同時執(zhí)行多個任務(wù)。例如,如果您的CPU是多核的,那么您可以讓CPU執(zhí)行一個線程。如果只有一個CPU,底層基于分時復用的原則,每個線程根據(jù)時間片獲得CPU資源。
java多線程在互聯(lián)網(wǎng)公司的應(yīng)用場景是什么?
老實說,具體的應(yīng)用場景還沒有研究過,但是四核I3已經(jīng)足夠日常使用了。順便說一下,今年I3已經(jīng)升級到四核八線程。
至于線程不應(yīng)該解釋它!讓一個核心做兩件核心的事情。事實上,從微觀層面看,仍然沒有改變。8核和16線程將用于什么場景?
首先,日常應(yīng)用程序絕對不可用,包括辦公軟件。不過,可能需要使用一些帶有配置的游戲,但它們也相對較少。
據(jù)我所知,即3D軟件渲染輸出,或視頻軟件合成輸出,使用3D當Max或類似軟件執(zhí)行靜態(tài)幀渲染時,渲染圖像上將出現(xiàn)多個動態(tài)幀。幀數(shù)表示當前渲染的線程數(shù)。當然,一般來說,這類任務(wù)的CPU是滿負荷的,也就是說,內(nèi)核和線程的數(shù)量是盡可能多的。實際上,8核和16線程根本算不了什么。
其余的不清楚。如果你真的想知道,你可以打開計算機的性能監(jiān)視器和實時監(jiān)視器,看看所有8核16線程都將使用什么場景。
實際工作中,什么場景會用到多線程開發(fā)?
20年前我問過一個人這個問題,然后他給我看了他們機房里的雙向主機,兩個370奔騰三CPU。當時,那套房子的價格足以在我們?nèi)壥I一套房。[機智]