這篇文章主要為大家展示了“AGG中內(nèi)存分配策略是什么”,內(nèi)容簡(jiǎn)而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“AGG中內(nèi)存分配策略是什么”這篇文章吧。
創(chuàng)新互聯(lián)從2013年成立,先為旬陽等服務(wù)建站,旬陽等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為旬陽企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。
說明
AGG采用new/delete函數(shù)操作堆內(nèi)存,有時(shí)候并不是最佳的選擇。另一方面,STL的內(nèi)存分配策略太繁瑣,因此沒有采用。在agg_allocator.h文件中描述目前內(nèi)存分配策略:
template
{
static T* allocate_array(unsigned size) { return new T [size]; }
static void free_array(T* v, unsigned) { delete [] v; }
};
具體用法如下:
char* array = allocator
allocator
理解
所有的內(nèi)存分配都是按照這種方法,沒有數(shù)組要求對(duì)數(shù)組元素進(jìn)行初始化工作。所有的分配數(shù)據(jù)都是POD類型。POD類型被認(rèn)為是C語言的結(jié)構(gòu)體,沒有攜帶任何的類的特性,能夠輕松的進(jìn)行memcpy或者strcpy。
可以自定義內(nèi)存分配器,例如:
template
{
static T* allocate_array(unsigned size)
{
return (T*)malloc(sizeof(T) * size);
}
static void free_array(T* v, unsigned size)
{
if(v) free(v);
}
};
應(yīng)用場(chǎng)景:創(chuàng)建自定義的超高效堆內(nèi)存
以上是“AGG中內(nèi)存分配策略是什么”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!