版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、TCMalloc:線程緩存的Malloc作者:SanjayGhemawatPaulMenage原文翻譯:ShiningRay動機(jī)TCMalloc要比glibc2.3的malloc(可以從一個叫作ptmalloc2的獨(dú)立庫獲得)和其他我測試過的malloc都快。ptmalloc在一臺2.8GHz的P4機(jī)器上(對于小對象)執(zhí)行一次malloc及free大約需要300納秒。而TCMalloc的版本同樣的操作大約只需要50納秒。malloc版本
2、的速度是至關(guān)重要的,因?yàn)槿绻鹠alloc不夠快,應(yīng)用程序的作者就很有可能在malloc之上寫一個自己的自由列表。這就可能導(dǎo)致額外的代碼復(fù)雜度,以及更多的內(nèi)存占用――除非作者本身非常仔細(xì)地劃分自由列表的大小并經(jīng)常從自由列表中清除空閑的對象。TCMalloc也減少了多線程程序中的鎖爭用情況。對于小對象,幾乎已經(jīng)達(dá)到了零爭用。對于大對象,TCMalloc嘗試使用粒度較好和有效的自旋鎖。ptmalloc同樣是通過使用每線程各自的場地來減少鎖爭用
3、,但是ptmalloc2使用每線程場地有一個很大的問題。在ptmalloc2中,內(nèi)存可能會從一個場地移動到另一個。這有可能導(dǎo)致大量空間被浪費(fèi)。例如,在一個Google的應(yīng)用中,第一階段可能會為其URL標(biāo)準(zhǔn)化的數(shù)據(jù)結(jié)構(gòu)分配大約300MB內(nèi)存。當(dāng)?shù)谝浑A段結(jié)束后,第二階段將從同樣的地址空間開始。如果第二個階段被安排到了一個與第一階段什用的場地不同的場地,這個階段不會復(fù)用任何第一階段留下的的內(nèi)存,并會給地址空間添加另外一個300MB。類似的內(nèi)存
4、爆炸問題也可以在其他的應(yīng)用中看到。TCMalloc的另一個好處是小對象的空間最優(yōu)表現(xiàn)形式。例如,分配N個8字節(jié)對象可能要使用大約8N1.01字節(jié)的空間。即,多用百分之一的空間。而ptmalloc2中每個對象都使用了一個四字節(jié)的頭,(我認(rèn)為)并將最終的尺寸規(guī)整為8字節(jié)的倍數(shù),最后使用了16N字節(jié)。使用要使用TCMalloc,只要將tcmalloc通過“l(fā)tcmalloc”鏈接器標(biāo)志接入你的應(yīng)用即可。你也可以通過使用LD_PRELOAD在不
5、是你自己編譯的應(yīng)用中使用tcmalloc:$LD_PRELOAD=“usrliblibtcmalloc.so“LD_PRELOAD比較討巧,我們也不十分推薦這種用法。TCMalloc還包含了一個堆檢查器以及一個堆測量器。如果你更想鏈接不包含堆測量器和檢查器的TCMalloc版本(比如可能為了減少靜態(tài)二進(jìn)制文件的大?。憧梢越尤雔ibtcmalloc_minimal。概覽?如果自由列表不空,那么從移除列表的第一個對象并返回它。當(dāng)按照這個
6、快速通道時,TCMalloc不會獲取任何鎖。這就可以極大提高分配的速度,因?yàn)殒i解鎖操作在一個2.8GHzXeon上大約需要100納秒的時間。如果自由列表為空:?從該尺寸類別的中央自由列表(中央自由列表是被所有線程共享的)取得一連串對象。?將他們放入線程局部的自由列表。?將新獲取的對象中的一個返回給應(yīng)用程序。如果中央自由列表也為空:(1)我們從中央頁分配器分配了一連串頁面。(2)將他們分割成該尺寸類的一系列對象。(4)像前面一樣,將部分對
7、象移入線程局部的自由列表中。大對象的分配一個大對象的尺寸(32K)會被除以一個頁面尺寸(4K)并取整(大于結(jié)果的最小整數(shù)),同時是由中央頁面堆來處理的。中央頁面堆又是一個自由列表的陣列。對于i=256個頁面的自由列表:k個頁面的一次分配通過在第k個自由列表中查找來完成。如果該自由列表為空,那么我們則在下一個自由列表中查找,如此繼續(xù)。最終,如果必要的話,我們將在最后一個自由列表中查找。如果這個動作也失敗了,我們將向系統(tǒng)獲取內(nèi)存(使用sbr
8、k、mmap或者通過在devmem中進(jìn)行映射)。如果k個頁面的一次分配行為由連續(xù)的長度k的頁面滿足了,剩下的連續(xù)頁面將被重新插回到頁面堆的對應(yīng)的自由列表中??缍龋⊿pan)TCMalloc管理的堆由一系列頁面組成。連續(xù)的頁面由一個“跨度”(Span)對象來表示。一個跨度可以是已被分配或者是自由的。如果是自由的,跨度則會是一個頁面堆鏈表中的一個條目。如果已被分配,它會是一個已經(jīng)被傳遞給應(yīng)用程序的大對象,或者是一個已經(jīng)被分割成一系列小對象的
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 一種基于緩存分區(qū)的線程間緩存干擾消除結(jié)構(gòu)的設(shè)計(jì)和實(shí)現(xiàn).pdf
- 流媒體服務(wù)器中線程與緩存結(jié)構(gòu)分析與研究.pdf
- 代理緩存集群緩存策略的研究.pdf
- 面向多線程分組分派的線程隊(duì)列狀態(tài)監(jiān)測技術(shù).pdf
- 基于TcMalloc的用戶態(tài)內(nèi)存管理軟件的研究與實(shí)現(xiàn).pdf
- 基于多線程應(yīng)用特性的多-眾核系統(tǒng)片上互連與緩存一致性整體優(yōu)化方法.pdf
- bcb線程池
- 面向通信優(yōu)化的MPSoC線程劃分與線程遷移方法研究.pdf
- 驗(yàn)證帶有線程動態(tài)創(chuàng)建和退出的多線程程序.pdf
- Web集群緩存系統(tǒng)中代理緩存技術(shù)的研究.pdf
- 基于緩存訪問規(guī)律的低級緩存優(yōu)化策略.pdf
- java多線程與線程安全實(shí)踐-基于http協(xié)議的斷點(diǎn)續(xù)傳
- 使用vc的mfc開發(fā)線程
- java 線程的掛起與喚醒
- redis頁面緩存html,使用redis實(shí)現(xiàn)頁面緩存
- linux多線程編程
- 多線程的內(nèi)存調(diào)度.pdf
- 驗(yàn)證帶有線程動態(tài)創(chuàng)建和退出多線程程序.pdf
- 操作系統(tǒng)課程設(shè)計(jì)--- 多線程管理與線程通信
- 高速緩存
評論
0/150
提交評論