日志:
譯者言:
歷史:ptmalloc2 基于 dlmalloc 開發(fā),其引入了多線程支持,于 2006 年發(fā)布。發(fā)布之后,ptmalloc2 整合進了 glibc 源碼,此后其所有修改都直接提交到了 glibc malloc 里。因此,ptmalloc2 的源碼和 glibc malloc 的源碼有很多不一致的地方。(譯者注:1996 年出現(xiàn)的 dlmalloc 只有一個主分配區(qū),該分配區(qū)為所有線程所爭用,1997 年發(fā)布的 ptmalloc 在 dlmalloc 的基礎(chǔ)上引入了非主分配區(qū)的概念。)
malloc
?內(nèi)部通過?brk
?或?mmap
?系統(tǒng)調(diào)用向內(nèi)核申請堆區(qū)。譯者注:在內(nèi)存管理領(lǐng)域,我們一般用「堆」指代用于分配動態(tài)內(nèi)存的虛擬地址空間,而用「?!怪复糜诜峙潇o態(tài)內(nèi)存的虛擬地址空間。具體到虛擬內(nèi)存布局(Memory Layout),堆維護在通過?brk
?系統(tǒng)調(diào)用申請的「Heap」及通過?mmap
?系統(tǒng)調(diào)用申請的「Memory Mapping Segment」中;而棧維護在通過匯編棧指令動態(tài)調(diào)整的「Stack」中。在 Glibc 里,「Heap」用于分配較小的內(nèi)存及主線程使用的內(nèi)存。下圖為 Linux 內(nèi)核 v2.6.7 之后,32 位模式下的虛擬內(nèi)存布局方式。
malloc
?時,只有一個線程能夠訪問臨界區(qū)(critical section)——這是因為所有線程共享用以緩存已釋放內(nèi)存的「空閑列表數(shù)據(jù)結(jié)構(gòu)」(freelist data structure),所以使用 dlmalloc 的多線程應(yīng)用會在?malloc
?上耗費過多時間,從而導(dǎo)致整個應(yīng)用性能的下降。在 ptmalloc2 中,當(dāng)兩個線程同時調(diào)用?malloc
?時,內(nèi)存均會得以立即分配——每個線程都維護著單獨的堆,各個堆被獨立的空閑列表數(shù)據(jù)結(jié)構(gòu)管理,因此各個線程可以并發(fā)地從空閑列表數(shù)據(jù)結(jié)構(gòu)中申請內(nèi)存。這種為每個線程維護獨立堆與空閑列表數(shù)據(jù)結(jié)構(gòu)的行為就「per thread arena」。/* 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(
網(wǎng)絡(luò)分配器就是把一路網(wǎng)絡(luò)信號分成幾路網(wǎng)絡(luò)信號,且每路信號電平相等的設(shè)備。使用分配器會有信號強度的損耗。2分配為4dB,3分配為6dB,4分配為8dB。分配器分成過流(電)型,和不過流型。就是
關(guān)鍵字: 分配器