項目中多線程使用場景 八核十六線程的Cpu有哪些不會性能過剩的應用場景?
八核十六線程的Cpu有哪些不會性能過剩的應用場景?一個非常重要的因素與操作系統(tǒng)和平臺有關。有一個很好的例子。在windows平臺上,由于效率問題和缺乏并行計算方案,8核16線程在大多數情況下可能是無用
八核十六線程的Cpu有哪些不會性能過剩的應用場景?
一個非常重要的因素與操作系統(tǒng)和平臺有關。有一個很好的例子。
在windows平臺上,由于效率問題和缺乏并行計算方案,8核16線程在大多數情況下可能是無用的。
但是在Linux平臺上是不一樣的,幾乎所有的科學計算或仿真軟件都是基于Linux平臺的,這種幾十萬的CPU使用太普遍了。
例如,目前所有的芯片設計軟件都是在Linux平臺上進行的,特別是先進技術(如7Nm)的設計極其復雜,設計規(guī)模巨大(100億設備規(guī)模)。使用幾十個或幾百個cpu和簡單線程運行模擬是很常見的。
因此,學習并行計算工具或模擬軟件。你會發(fā)現8核和16線程有時是不夠的
這里有一個簡單的解釋,原因如下:
鎖定是因為操作不是原子的。讓我們把我的手術作為一個解釋。參見下面兩個圖。
我這個操作需要
看上面的第二個圖,你能很清楚地理解這個過程嗎?
鎖定是為了確保上述三個步驟是原子操作。
回到問題上來,只有一個線程要寫,沒有競爭,所以不需要鎖定。
但是,如果你看第一張圖片,因為主內存和本地內存的存在
在一個線程寫入后,其他線程無法立即看到它。這就是可見性問題。
添加volatile關鍵字后,它將在操作后強制工作內存和主內存同步,以確保其他線程可以立即看到它。
多個線程可以讀一個變量,只有一個線程可以對這個變量進行寫,到底要不要加鎖?
20年前我問過一個人這個問題,然后他給我看了他們機房里的雙向主機,兩個370奔騰三CPU。當時,那套房子的價格足以在我們三級省會買一套房。[機智
都有這個痛點,但痛點不同,沒辦法。程序員就是這樣。項目開發(fā)是一個人負責開發(fā)的部分內容模塊。大項目可以,每個人都開發(fā)更多的東西。小型項目沒有高并發(fā)性和多線程開發(fā)。
以前做輕應用開發(fā)的時候,我想在微信平臺上開發(fā),但是沒有成功。我不得不服從公司的安排。我只能從頭到尾在金蝶移動云上寫輕量應用。雖然我覺得它幾乎是基于某個平臺,但我心里還是有一個缺口。
開發(fā)人員希望接觸一些他們沒有做過的事情來提高技術。然而,現實是殘酷的。遇到項目時,公司有現成的技術。成熟的開發(fā)者肯定不會讓不熟悉某項技術的人去開發(fā)。
作為開發(fā)者,他們只能利用業(yè)余時間學習,搭建自己的電腦虛擬環(huán)境,安裝好數據庫,找一些數據導入,私下探索,或者拿別人的程序模仿學習。
當程序員在工作中遇到不熟悉的技術時,他們總是同時學習和做。這是正常情況。沒有別的辦法了。