这篇文章主要为大家展示了“编程语言中如何实现一个内存池管理的类方法”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“编程语言中如何实现一个内存池管理的类方法”这篇文章吧。
创新互联建站是一家集成都做网站、成都网站建设、网站页面设计、网站优化SEO优化为一体的专业的建站公司,已为成都等多地近百家企业提供网站建设服务。追求良好的浏览体验,以探求精品塑造与理念升华,设计最适合用户的网站页面。 合作只是第一步,服务才是根本,我们始终坚持讲诚信,负责任的原则,为您进行细心、贴心、认真的服务,与众多客户在蓬勃发展的市场环境中,互促共生。模拟STL中的freelist,有这个思想在内。
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; };
以上是“编程语言中如何实现一个内存池管理的类方法”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联网站建设公司行业资讯频道!
另外有需要云服务器可以了解下创新互联建站www.cdcxhl.com,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。