简单的内存池分析
来源:互联网 发布:linux 复制覆盖文件 编辑:程序博客网 时间:2024/06/10 19:29
//代码引用了百度百科
typedef unsigned char UCHAR;template<class T,int BLOCK_NUM=50>class GenericMP{public: static VOID* operator new(size_t allocLen) { if (!m_NewPointer) MyAlloc(); UCHAR* rp = m_NewPointer; m_NewPointer = *reinterpret_cast<UCHAR**>(rp); return rp; } static VOID operator delete(VOID* dp) { *reinterpret_cast<UCHAR**>(dp) = m_NewPointer; m_NewPointer = static_cast<UCHAR*>(dp); }private: static VOID MyAlloc() { m_NewPointer = new UCHAR[sizeof(T)*BLOCK_NUM]; UCHAR** cur = reinterpret_cast<UCHAR**>(m_NewPointer); UCHAR* next = m_NewPointer; for (int i = 0; i < BLOCK_NUM-1; i++) { next += sizeof(T); *cur = next; cur = reinterpret_cast<UCHAR**>(next); } *cur = 0; } static UCHAR* m_NewPointer;protected: ~GenericMP(){}};template<class T,int BLOCK_NUM>UCHAR* GenericMP<T,BLOCK_NUM>::m_NewPointer;class ExpMP : public GenericMP<ExpMP>{ UCHAR a[1024];};int _tmain(int argc, _TCHAR* argv[]){ ExpMP* aMP = new ExpMP; delete aMP; system("pause"); return 0;}
其中new的时候调用了私有的MyAlloc()函数,该函数分配预先设好大小的内存,然后通过类型转换
- synamic_cast一般用在父类和子类指针或应用的互相转化;
- static_cast一般是普通数据类型(如int m=static_cast<int>(3.14));
- reinterpret_cast很像c的一般类型转换操作
- const_cast是把cosnt或volatile属性去掉
第三种对指针转成指针的指针,也就是前4个字节,用这前4个字节存储下一块内存的首地址,结构类似于链表,而重载的new操作符只在第一次分配内存,随后都是直接分配事先分配好的地址。删除内存的时候也是把该内存加回去,类似链表操作。
- 简单的内存池分析
- 简单的内存分析
- 对象的简单内存分析
- Java程序内存的简单分析
- Java内存泄漏简单的分析总结
- Java程序内存的简单分析
- 简单的内存池
- 关于内存泄漏和内存分析检测的简单描述
- Java内存简单分析
- 简单内存溢出分析
- Java内存简单分析
- 简单的内存池模型
- 简单的内存池 MemoryPool
- 简单的内存对象池
- 内存池的简单实现
- 简单内存池的实现
- 简单的内存池实现
- 一个简单的内存池
- 消息队列RabbitMQ和ActiveMQ的生产者流量控制
- 使用wait()与notify()改写上面的例子
- 12组nodes MySQL DB,每组2台Master-Master,批量清除过期的binlog释放磁盘空间
- android软件创建快捷方式
- fedora centos,ubuntu关于进程资源限制的问题
- 简单的内存池分析
- 加入header的自定义GridView
- Apache——Rewrite重写规则
- 大数据量,海量数据 处理方法总结
- 2013 ACM/ICPC 长沙网络赛B题解题报告
- Cocos2d-x学习之搭建coocs2d-x2.1.5并编译到android和ios
- 通过www.ip138.com获取本机外网ip以及所在地理位置
- merge attachDirty attachClean用法.
- valgrind使用心得