這篇文章主要為大家展示了“編程語言中如何實現(xiàn)一個內(nèi)存池管理的類方法”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“編程語言中如何實現(xiàn)一個內(nèi)存池管理的類方法”這篇文章吧。
桃山ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場景,ssl證書未來市場廣闊!成為創(chuàng)新互聯(lián)建站的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:028-86922220(備注:SSL證書合作)期待與您的合作!
模擬STL中的freelist,有這個思想在內(nèi)。
union obj { union obj* next; char p[1]; }; class MemoryPool { public: MemoryPool() { union obj* temp; m_memory.assign(5,(union obj*)NULL); for(int i=0;inext = m_memory[i]; m_memory[i] = temp; } } } char* mem_get(int size) { int j; if( size > 128) { char* start = (char*)malloc(sizeof(char)*size); return start; } int index = freelist_index(size); obj* temp = m_memory[index]; if(temp == NULL) // { for(j = index+1;j next; break; } } if(j>= m_memory.size()) { for(int j=0;j next = m_memory[index]; m_memory[index] = temp; } temp = m_memory[index]; m_memory[index] = temp->next; return (char*)temp; } else { obj* cur; int up_size = round_up(size); for(int i=0;i<(1<<(j-index));i++) { cur = temp; cur->next = m_memory[index]; m_memory[index] = cur; temp = cur+up_size; } temp = m_memory[index]; m_memory[index] = temp->next; return (char*)temp; } } else { m_memory[index] = temp->next; return (char*)temp; } } void mem_free(void* p,int size) { if(size > 128) { free(p); return ; } obj* temp = (obj*)p; int index = freelist_index(size); temp->next = m_memory[index]; m_memory[index] = temp; } private: enum {_ALIGN = 8};// int freelist_index(int __bytes) { return (((__bytes) + (int)_ALIGN-1)/(size_t)_ALIGN - 1); } int round_up(int __bytes) { return (((__bytes) + (int) _ALIGN-1) & ~((int) _ALIGN - 1)); } vector m_memory; };
以上是“編程語言中如何實現(xiàn)一個內(nèi)存池管理的類方法”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!