www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當前位置:首頁 > 單片機 > CPP開發(fā)者
[導讀]↓推薦關注↓前言堆內存(HeapMemory)是一個很有意思的領域。你可能和我一樣,也困惑于下述問題很久了:如何從內核申請堆內存?誰管理它?內核、庫函數(shù),還是應用本身?內存管理效率怎么這么高?!堆內存的管理效率可以進一步提高嗎?最近,我終于有時間去深入了解這些問題。下面就讓我來談...

前言
堆內存(Heap Memory)是一個很有意思的領域。你可能和我一樣,也困惑于下述問題很久了:


  • 如何從內核申請堆內存?
  • 誰管理它?內核、庫函數(shù),還是應用本身?
  • 內存管理效率怎么這么高?!
  • 堆內存的管理效率可以進一步提高嗎?
最近,我終于有時間去深入了解這些問題。下面就讓我來談談我的調研成果。


開源社區(qū)公開了很多現(xiàn)成的內存分配器(Memory Allocators,以下簡稱為分配器):


  • dlmalloc – 第一個被廣泛使用的通用動態(tài)內存分配器;
  • ptmalloc2 – glibc 內置分配器的原型;
  • jemalloc – FreeBSD & Firefox 所用分配器;
  • tcmalloc – Google 貢獻的分配器;
  • libumem – Solaris 所用分配器;
每一種分配器都宣稱自己快(fast)、可拓展(scalable)、效率高(memory efficient)!但是并非所有的分配器都適用于我們的應用。內存吞吐量大(memory hungry)的應用程序,其性能很大程度上取決于分配器的性能。


在這篇文章中,我只談「glibc malloc」分配器。為了方便大家理解「glibc malloc」,我會聯(lián)系最新的源代碼。


歷史:ptmalloc2 基于 dlmalloc 開發(fā),其引入了多線程支持,于 2006 年發(fā)布。發(fā)布之后,ptmalloc2 整合進了 glibc 源碼,此后其所有修改都直接提交到了 glibc malloc 里。因此,ptmalloc2 的源碼和 glibc malloc 的源碼有很多不一致的地方。(譯者注:1996 年出現(xiàn)的 dlmalloc 只有一個主分配區(qū),該分配區(qū)為所有線程所爭用,1997 年發(fā)布的 ptmalloc 在 dlmalloc 的基礎上引入了非主分配區(qū)的概念。)


1. 申請堆的系統(tǒng)調用

我在之前的文章中提到過,malloc內部通過brk或mmap系統(tǒng)調用向內核申請堆區(qū)。


譯者注:在內存管理領域,我們一般用「堆」指代用于分配動態(tài)內存的虛擬地址空間,而用「棧」指代用于分配靜態(tài)內存的虛擬地址空間。具體到虛擬內存布局(Memory Layout),堆維護在通過brk系統(tǒng)調用申請的「Heap」及通過mmap系統(tǒng)調用申請的「Memory Mapping Segment」中;而棧維護在通過匯編棧指令動態(tài)調整的「Stack」中。在 Glibc 里,「Heap」用于分配較小的內存及主線程使用的內存。


下圖為 Linux 內核 v2.6.7 之后,32 位模式下的虛擬內存布局方式。


2. 多線程支持

Linux 的早期版本采用 dlmalloc 作為它的默認分配器,但是因為 ptmalloc2 提供了多線程支持,所以 后來 Linux 就轉而采用 ptmalloc2 了。多線程支持可以提升分配器的性能,進而間接提升應用的性能。


在 dlmalloc 中,當兩個線程同時malloc時,只有一個線程能夠訪問臨界區(qū)(critical section)——這是因為所有線程共享用以緩存已釋放內存的「空閑列表數(shù)據(jù)結構」(freelist data structure),所以使用 dlmalloc 的多線程應用會在malloc上耗費過多時間,從而導致整個應用性能的下降。


在 ptmalloc2 中,當兩個線程同時調用malloc時,內存均會得以立即分配——每個線程都維護著單獨的堆,各個堆被獨立的空閑列表數(shù)據(jù)結構管理,因此各個線程可以并發(fā)地從空閑列表數(shù)據(jù)結構中申請內存。這種為每個線程維護獨立堆與空閑列表數(shù)據(jù)結構的行為就「per thread arena」。


2.1. 案例代碼

/* Per thread arena example. */
#include 
#include 
#include
#include 
#include 

void* threadFunc(void* arg) {
printf("Before malloc in thread 1\n");
getchar();
char* addr = (char*) malloc(1000);
printf("After malloc and before free in thread 1\n");
getchar();
free(addr);
printf("After free in thread 1\n");
getchar();
}

int main() {
pthread_t t1;
void* s;
int ret;
char* addr;

printf("Welcome to per thread arena example::%d\n",getpid());
printf("Before malloc in main thread\n");
getchar();
addr = (char*) malloc(1000);
printf("After malloc and before free in main thread\n");
getchar();
free(addr);
printf("After free in main thread\n");
getchar();
ret = pthread_create(
本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: 驅動電源

在工業(yè)自動化蓬勃發(fā)展的當下,工業(yè)電機作為核心動力設備,其驅動電源的性能直接關系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護是驅動電源設計中至關重要的兩個環(huán)節(jié),集成化方案的設計成為提升電機驅動性能的關鍵。

關鍵字: 工業(yè)電機 驅動電源

LED 驅動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設備的使用壽命。然而,在實際應用中,LED 驅動電源易損壞的問題卻十分常見,不僅增加了維護成本,還影響了用戶體驗。要解決這一問題,需從設計、生...

關鍵字: 驅動電源 照明系統(tǒng) 散熱

根據(jù)LED驅動電源的公式,電感內電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關鍵字: LED 設計 驅動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動汽車的核心技術之一是電機驅動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機驅動系統(tǒng)中的關鍵元件,其性能直接影響到電動汽車的動力性能和...

關鍵字: 電動汽車 新能源 驅動電源

在現(xiàn)代城市建設中,街道及停車場照明作為基礎設施的重要組成部分,其質量和效率直接關系到城市的公共安全、居民生活質量和能源利用效率。隨著科技的進步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關鍵字: 發(fā)光二極管 驅動電源 LED

LED通用照明設計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關鍵字: LED 驅動電源 功率因數(shù)校正

在LED照明技術日益普及的今天,LED驅動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關鍵字: LED照明技術 電磁干擾 驅動電源

開關電源具有效率高的特性,而且開關電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機重量也有所下降,所以,現(xiàn)在的LED驅動電源

關鍵字: LED 驅動電源 開關電源

LED驅動電源是把電源供應轉換為特定的電壓電流以驅動LED發(fā)光的電壓轉換器,通常情況下:LED驅動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: LED 隧道燈 驅動電源
關閉