CPU基本知識大全
CPU 的全稱是 Central Processing Unit(中央處理器),是電腦中最硬核組件。CPU 是計算機最核心組件。CPU 核心:從程序或應用程序獲取指令并執(zhí)行計算。這個過程可以分為三個關(guān)鍵階段:提取,解碼和執(zhí)行。下面就讓小編帶你去看看CPU基本知識大全,希望能幫助到大家!
CPU超頻小知識:CPU什么情況下需要超頻?CPU超頻需要什么條件?
一、什么是CPU頻率嗎?
CPU頻率其實就是指CPU在一秒內(nèi)發(fā)生脈沖的次數(shù),單位是赫茲,同一款CPU在一秒內(nèi)發(fā)生脈沖的次數(shù)越多,就說明它的運行速度越快。
二、CPU超頻有什么用?
CPU超頻的作用是可以使工作頻率提高,并讓其在高于其額定的頻率狀態(tài)下穩(wěn)定工作,能夠讓cpu發(fā)揮更強大的性能,以提高電腦的運行速度。通常所說的超頻簡單來說就是人為提高CPU的外頻或倍頻,使之運行頻率得到大幅提升,即CPU超頻。
公式:CPU主頻=CPU倍頻__CPU外頻;
舉個例子:
例如:i7 9700K基礎(chǔ)頻率大小3.6GHz,通過設(shè)置超頻,讓其頻率固定在5Ghz,超過它原來限制的頻率上。
打個比方說,我們在跑步的時候,以5米/S的速度進行跑步,但是您想要快點跑到終點,這時候您就需要加速跑,這時您的速度調(diào)到了7米/S,你的步頻就加快了。
三、CPU超頻需要什么條件?
1、CPU需要支持超頻
intel在CPU市場實行了嚴格的產(chǎn)品等級劃分,只有CPU帶K后綴的型號,例如i7-9700K,才可以支持超頻,其它CPU頻率已經(jīng)鎖死了。而AMD這邊良心點,因為要搶占市場份額,目前幾乎全系CPU采用不鎖頻技術(shù),均支持超頻。
2、主板需要支持超頻
在intel主板芯片組中,Z開頭才支持超頻,例如Z370、Z390主板,而在AMD主板芯片組中,__開頭、B開頭的主板芯片組支持超頻,例如__470、B450。一般主板采用6相核心供電或者更多的主板就可以進行超頻嘗試。
3、CPU散熱器加強
由于CPU超頻之后,會帶來更高的溫度表現(xiàn),如果散熱器太垃圾,超頻產(chǎn)生的巨量熱量無法盡快散熱,導致溫度飆升,CPU穩(wěn)定性就會大大折扣。
4、電源功率
超頻后CPU的耗電是大幅度增加,所以電源功率有合理預留一定的空間。
四、CPU什么情況下需要超頻?
當你對這塊CPU的性能不滿意的時候,這時候可以考慮通過超頻來提升性能。
五、超頻對cpu的影響
由于CPU超頻之后,主板和CPU的溫度升高,對硬件使用壽命會有一定的影響。如果超頻不當,還有可能造成CPU損壞、縮肛(CPU無法穩(wěn)定運行在默認出廠的頻率上)等問題。
以上就是裝機之家分享的CPU超頻小知識,如果CPU在平時夠用的情況下,是無需超頻的,正常使用即可,只有當性能不夠的情況下,例如老處理器,才可以嘗試超頻,以提高CPU的性能。
CPU 高速緩存知識
01概述
在計算機系統(tǒng)中,CPU高速緩存(英語:CPU Cache,在本文中簡稱緩存)是用于減少處理器訪問內(nèi)存所需平均時間的部件。在金字塔式存儲體系中它位于自頂向下的第二層,僅次于CPU寄存器。其容量遠小于內(nèi)存,但速度卻可以接近處理器的頻率。
當處理器發(fā)出內(nèi)存訪問請求時,會先查看緩存內(nèi)是否有請求數(shù)據(jù)。如果存在(命中),則不經(jīng)訪問內(nèi)存直接返回該數(shù)據(jù);如果不存在(失效),則要先把內(nèi)存中的相應數(shù)據(jù)載入緩存,再將其返回處理器。
緩存之所以有效,主要是因為程序運行時對內(nèi)存的訪問呈現(xiàn)局部性(Locality)特征。這種局部性既包括空間局部性(Spatial Locality),也包括時間局部性(Temporal Locality)。有效利用這種局部性,緩存可以達到極高的命中率。
在處理器看來,緩存是一個透明部件。因此,程序員通常無法直接干預對緩存的操作。但是,確實可以根據(jù)緩存的特點對程序代碼實施特定優(yōu)化,從而更好地利用緩存。
02CPU 的多級緩存
CPU 緩存離 CPU 核心更近,由于電子信號傳輸是需要時間的,所以離 CPU 核心越近,緩存的讀寫速度就越快。但 CPU 的空間很狹小,離 CPU 越近緩存大小受到的限制也越大。所以,綜合硬件布局、性能等因素,CPU 緩存通常分為大小不等的三級緩存。
CPU 緩存的材質(zhì) SRAM 比內(nèi)存使用的 DRAM 貴許多,所以不同于內(nèi)存動輒以 GB 計算,它的大小是以 MB 來計算的。比如,在我的 Linu__ 系統(tǒng)上,離 CPU 最近的一級緩存是 32KB,二級緩存是 256KB,最大的三級緩存則是 20MB。
你可能注意到,三級緩存要比一、二級緩存大許多倍,這是因為當下的 CPU 都是多核心的,每個核心都有自己的一、二級緩存,但三級緩存卻是一顆 CPU 上所有核心共享的。
程序執(zhí)行時,會先將內(nèi)存中的數(shù)據(jù)載入到共享的三級緩存中,再進入每顆核心獨有的二級緩存,最后進入最快的一級緩存,之后才會被 CPU 使用,就像下面這張圖。
通過上圖可以知道:
L1緩分成兩種,一種是指令緩存,一種是數(shù)據(jù)緩存。L2緩存和L3緩存不分指令和數(shù)據(jù)。
L1和L2緩存在每一個CPU核中,L3則是所有CPU核心共享的內(nèi)存。
L1、L2、L3的越離CPU近就越小,速度也越快,越離CPU遠,速度也越慢。
緩存要比內(nèi)存快很多,那么我們來看下他們的訪問速度是什么樣的。
L1 的存取速度:4 個CPU時鐘周期
L2 的存取速度:11 個CPU時鐘周期
L3 的存取速度:30 個CPU時鐘周期
RAM內(nèi)存的存取速度:100 個CPU時鐘周期以上
根據(jù)上面的訪問速度可知,如果 CPU 所要操作的數(shù)據(jù)在緩存中,則直接讀取,這稱為緩存命中。命中緩存會帶來很大的性能提升,因此,我們的代碼優(yōu)化目標是提升 CPU 緩存的命中率。
通常我們查看 CPU 緩存時會發(fā)現(xiàn)有 2 個一級緩存(比如 Linu__ 上就是上圖中的 inde__0 和 inde__1),這是因為,CPU 會區(qū)別對待指令與數(shù)據(jù)。比如,“1+1=2”這個運算,“+”就是指令,會放在一級指令緩存中,而“1”這個輸入數(shù)字,則放在一級數(shù)據(jù)緩存中。雖然在馮諾依曼計算機體系結(jié)構(gòu)中,代碼指令與數(shù)據(jù)是放在一起的,但執(zhí)行時卻是分開進入指令緩存與數(shù)據(jù)緩存的,因此我們要分開來看二者的緩存命中率。
03提升L1數(shù)據(jù)緩存的命中率
在說明這個問題之前。我們需要了解一個術(shù)語 Cache Line。緩存基本上來說就是把后面的數(shù)據(jù)加載到離自己近的地方,對于CPU來說,它是不會一個字節(jié)一個字節(jié)的加載的,因為這非常沒有效率,一般來說都是要一塊一塊的加載的,對于這樣的一塊一塊的數(shù)據(jù)單位,術(shù)語叫“Cache Line”,一般來說,一個主流的CPU的Cache Line 是 64 Bytes,64Bytes也就是16個32位的整型,這就是CPU從內(nèi)存中撈數(shù)據(jù)上來的最小數(shù)據(jù)單位。
比如:Cache Line是最小單位(64Bytes),所以先把Cache分布多個Cache Line,比如:L1有32KB,那么,32KB/64B = 512 個 Cache Line。
Linu__ 上你可以通過 coherency_line_size 配置查看它。
Cache的數(shù)據(jù)放置的策略決定了內(nèi)存中的數(shù)據(jù)塊會拷貝到CPU Cache中的哪個位置上,因為Cache的大小遠遠小于內(nèi)存,所以,需要有一種地址關(guān)聯(lián)的算法,能夠讓內(nèi)存中的數(shù)據(jù)可以被映射到Cache中來。這個有點像內(nèi)存地址從邏輯地址向物理地址映射的方法,但不完全一樣。
基本上來說,我們通常會想到如下的算法:
一種方法是,任何一個內(nèi)存地址的數(shù)據(jù)可以被緩存在任何一個Cache Line里,這種方法是最靈活的,但是,如果我們要知道一個內(nèi)存是否存在于Cache中,我們就需要進行O(n)復雜度的Cache遍歷,這是很沒有效率的。
另一種方法,為了降低緩存搜索算法,我們需要使用像Hash Table這樣的數(shù)據(jù)結(jié)構(gòu),最簡單的hash table就是做“求模運算”,比如:我們的L1 Cache有512個Cache Line,那么,公式:(內(nèi)存地址 mod 512)__ 64 就可以直接找到所在的Cache地址的偏移了。但是,這樣的方式需要我們的程序?qū)?nèi)存地址的訪問要非常地平均,不然沖突就會非常嚴重。這成了一種非常理想的情況了。
為了避免上述的兩種方案的問題,于是就要容忍一定的hash沖突,也就出現(xiàn)了 N-Way 關(guān)聯(lián)。也就是把連續(xù)的N個Cache Line綁成一組,然后,先把找到相關(guān)的組,然后再在這個組內(nèi)找到相關(guān)的Cache Line。這叫 Set Associativity。如下圖所示。
對于 N-Way 組關(guān)聯(lián),可能有點不好理解,舉個例子進行說明,Intel 大多數(shù)處理器的L1 Cache都是32KB,8-Way 組相聯(lián),Cache Line 是64 Bytes。
這意味著,
32KB的可以分成,32KB / 64 = 512 條 Cache Line。
因為有8 Way,于是會每一Way 有 512 / 8 = 64 條 Cache Line。
于是每一路就有 64 __ 64 = 4096 Byts 的內(nèi)存。
為了方便索引內(nèi)存地址,
Tag:每條 Cache Line 前都會有一個獨立分配的 24 bits用來存的 tag,其就是內(nèi)存地址的前24bits
Inde__:內(nèi)存地址后續(xù)的6個bits則是在這一Way的是Cache Line 索引,2^6 = 64 剛好可以索引64條Cache Line
Offset:再往后的6bits用于表示在Cache Line 里的偏移量
當拿到一個內(nèi)存地址的時候,先拿出中間的 6bits 來,找到是哪組。
然后,在這一個8組的cache line中,再進行O(n) n=8 的遍歷,主要是要匹配前24bits的tag。如果匹配中了,就算命中,如果沒有匹配到,那就是cache miss,如果是讀操作,就需要進向后面的緩存進行訪問了。L2/L3同樣是這樣的算法。而淘汰算法有兩種,一種是隨機一種是LRU?,F(xiàn)在一般都是以LRU的算法(通過增加一個訪問計數(shù)器來實現(xiàn))
這也意味著:
L1 Cache 可映射 36bits 的內(nèi)存地址,一共 2^36 = 64GB的內(nèi)存
當CPU要訪問一個內(nèi)存的時候,通過這個內(nèi)存中間的6bits 定位是哪個set,通過前 24bits 定位相應的Cache Line。
就像一個hash Table的數(shù)據(jù)結(jié)構(gòu)一樣,先是O(1)的索引,然后進入沖突搜索。
因為中間的 6bits 決定了一個同一個set,所以,對于一段連續(xù)的內(nèi)存來說,每間隔4096的內(nèi)存會被放在同一個組內(nèi),導致緩存沖突。
此外,當有數(shù)據(jù)沒有命中緩存的時候,CPU就會以最小為Cache Line的單元向內(nèi)存更新數(shù)據(jù)。當然,CPU并不一定只是更新64Bytes,因為訪問主存實在是太慢了,所以,一般都會多更新一些。好的CPU會有一些預測的技術(shù),如果找到一種pattern的話,就會預先加載更多的內(nèi)存,包括指令也可以預加載。這叫 Prefetching 技術(shù)。關(guān)于預取技術(shù)是如何影響性能的請看我們下面的案例。
CPU(一篇有點搞笑的CPU科普)
主頻:
我們常在CPU的信息里看到 3.0GHz、3.7GHz等就是CPU的主頻,嚴謹?shù)恼f他是CPU內(nèi)核的時鐘頻率,但是我們也可以直接理解為運算速度。
舉個有趣的例子:CPU的主頻相當于我們胳膊的肌肉(力量),主頻越高,力量越大。
核心:
我們更多聽到的是,這個CPU是幾核幾核的。如2核、4核、6核、8核、16核等等。
這個核心可以理解為我們?nèi)祟惖母觳玻?核就是兩條胳膊,4核就是4條胳膊,6核就是6條胳膊。
線程:
光有胳膊(核心)和肌肉(頻率)是干不了活的,還必須要有手(線程)才行。
一般來說,單核配單線程、雙核配雙線程,就相當于一條胳膊長一只手。后來由于技術(shù)越來越厲害,造出了一條胳膊長兩只手的情況,這樣干活的效率就大大的提高了。
架構(gòu):
現(xiàn)在胳膊有了,肌肉有了,手也有了,就差一個工具就可以干活了,這個工具就是CPU的架構(gòu),架構(gòu)對性能的影響巨大。
所以說有句話叫“拋開架構(gòu)看核心、頻率都是耍流氓!”這就是為啥以前AMD的CPU雖然核心數(shù)量和頻率都比同時期的英特爾高,但是依然流傳著“i3戰(zhàn)A8,i5秒全家、i7轟成渣”這樣的說法了。
這個時候可能有的人不理解了,怎么看架構(gòu)呢?這個其實不用擔心,因為一般來說,每一代CPU的架構(gòu)都是一樣的,比如i3-8100、i5-8500、i7-8700都是8代的CPU,使用的架構(gòu)也是一樣的,現(xiàn)在官方店在售的也都是最新款。
緩存:
緩存也是CPU里一項很重要的參數(shù)。由于CPU的運算速度特別快,在內(nèi)存條的讀寫忙不過來的時候,CPU就可以把這部分數(shù)據(jù)存入緩存中,以此來緩解CPU的運算速度與內(nèi)存條讀寫速度不匹配的矛盾,所以緩存是越大越好。
參數(shù)就算是說完了。既然開頭就說了“CPU也跟人腦一樣,術(shù)業(yè)有專攻?!蹦墙酉聛砭头治鲆徊ǎ裁礃拥腢適合干什么樣的工作。
游戲:
由于游戲運行需要的是粗暴直接的計算工作,所以主頻高的CPU會更有優(yōu)勢。
這就好比我的工作是要搬個磚,肌肉強點,力氣大才是硬性需求。就算我有8條胳膊16只手,看起來張牙舞爪的很厲害,但是我搬磚的時候根本用不到,而且這些胳膊大多力氣又小,所以效果并不會很好。
所以,有游戲需求的玩家可以選擇主頻高點的CPU,核心和線程數(shù)少一點無所謂。(4核4線程就差不多了)
整體來說,英特爾i3、i5、i7和銳龍2代的CPU主頻都挺高的,很適合玩游戲。英特爾后面帶“K”的CPU不僅主頻更高,而且是支持超頻的(需要用Z系或__系主板)。新出的銳龍2代CPU主頻也很高,而且性價比也還不錯。
圖形渲染等工作需求:
對于需要進行大量并行運算的圖形渲染來說,多核心多線程同時工作能比單核心高主頻的傻大粗節(jié)省大量的時間。
綠巨人雖然搬磚能力出眾,但是如果讓他去完成一幅復雜的拼圖,速度自然是比那種有多條胳膊和多只手同時工作的小機靈慢了不少。
適合圖形渲染和視頻制作的CPU:
日常家用,偶爾玩LOL、DNF等
這一類的用戶平時就是看看網(wǎng)頁,看看視頻、看文檔、玩玩LOL、DNF等游戲。
這類用戶可以選擇自帶核顯的CPU,如699元的AMD 銳龍3 2200G、英特爾600塊的奔騰G5500,或者800元的i3-8100。這類CPU的自帶的HD630核顯完全可以輕松解碼4K視頻以及流暢運行LOL、DNF這類游戲,省下的錢買塊固態(tài)硬盤,加條內(nèi)存豈不是美滋滋。(使用核顯請盡量組雙通道內(nèi)存條,為什么可以看我內(nèi)存條的文章)
總結(jié):
1.游戲用戶選擇高主頻的CPU,4核4線程差不多就夠用了。如英特爾i3-8350K、i5-8600K(這種帶K的CPU還可以通過超頻來達到更高的頻率,不過要搭配較貴的Z370系主板使用);銳龍二代CPU也很不錯,建議購買后綴帶__的如 銳龍R5 2600__,雖然本身性價比并不突出,但是好在可以搭配AMD平臺較便宜的B350主板進行超頻。
2.對于需要做圖形渲染工作的用戶來說,多核心多線程的CPU是最優(yōu)的選擇。AMD多核心多線程的銳龍系列性價比非常的高。
3.普通用戶,如果沒有大型游戲需求,AMD的銳龍R3 2200G絕對是最有性價比的選擇。首先是4核4線程3.5GHz,性能足夠用,而且自帶的核顯性能也不俗,LOL、DNF毫無壓力,還能省下買顯卡的錢。
4.選擇CPU的時候,一定要詢問店家是不是支持自己的主板。有時候雖然接口針腳數(shù)量是一樣的,但是可能并不兼容。(英特爾,別左右瞎看了,說的就是你)