自从很久以前看了侯捷老师的《池内春秋》一文后
就有想把sgi stl中的memory pool搞出来自己用
但是一直没动手……
要学的东西实在是太多了……

认为只要大量使用std::container就可以不用自己写内存池了
例如用std::vector<char>代替new char []

上次C++大会,听到云风谈到在写server端时,自己操作内存池是很有必要的

12月份看到《游戏创造》中有一文已实现了最初的想法
照文中所说去网站却下载不到源码,郁闷……

开始自己动手翻资料写程序
原来很简单……
struct Base
{
    
float sz[64];

/*
    virtual ~Base()
    {
    }
*/

}
;

struct Test : public Base
{
}
;

struct TestAlloc : public Base
{
    
static std::allocator<char> alloc;

    
static void *operator new(size_t size)
    
{
        
if (size > 128)
            
return ::operator new(size);
        
else
            
return alloc.allocate(size);
    }

    
    
static void operator delete(void* p, size_t size)
    
{
        
if (size > 128)
            ::
operator delete(p);
        
else
            alloc.deallocate(static_cast
<char *>(p), size);
    }

}
;
std::allocator
< char > TestAlloc::alloc;

测试了一下
int _tmain(int argc, _TCHAR* argv[])
{
    
const Times = 10000000;

    DWORD begin 
= 0, end = 0;
    
    begin 
= GetTickCount();
    
for (size_t n=0; n<Times; ++n)
    
{
        Test 
*= new Test;
        delete p;
    }

    end 
= GetTickCount();
    std::cout 
<< "Test time :" << end - begin << std::endl;


    begin 
= GetTickCount();
    
for (size_t n=0; n<Times; ++n)
    
{
        TestAlloc 
*= new TestAlloc;
        delete p;
    }

    end 
= GetTickCount();
    std::cout 
<< "TestAlloc time :" << end - begin << std::endl;

    
return 0;
}


发现要比普通的快近一倍
但是也正如文中所说,>128 bytes的还是使用::operator new/delete
不爽ing~

再仔细看文章
发现一个关键字Doug Lea
然后找到这里http://gee.cs.oswego.edu/dl/html/malloc.html
发现他的想法与sgi stl类似,但是没有128的限制,竟然是
 

爽了~

备份资料
引用自http://www-128.ibm.com/developerworks/cn/linux/l-memory/?ca=dwcn-newsletter-linux#resources

参考资料

  • 您可以参阅本文在 developerWorks 全球站点上的 英文原文
Web 上的文档 基本的分配程序 池式分配程序 智能指针和定制分配程序
  • Loki C++ Library 有很多为 C++ 实现的通用模式,包括智能指针和一个定制的小对象分配程序。
垃圾收集器 关于现代操作系统中的虚拟内存的文章 关于 malloc 的文章 关于定制分配程序的文章 关于垃圾收集的文章 Web 上的通用参考资料 书籍 来自 developerWorks
  • 自我管理数据缓冲区内存 (developerWorks,2004 年 1 月)略述了一个用于管理内存的自管理的抽象数据缓存器的伪 C (pseudo-C)实现。

  • A framework for the user defined malloc replacement feature (developerWorks,2002 年 2 月)展示了如何利用 AIX 中的一个工具,使用自己设计的内存子系统取代原有的内存子系统。

  • 掌握 Linux 调试技术 (developerWorks,2002 年 8 月)描述了可以使用调试方法的 4 种不同情形:段错误、内存溢出、内存泄漏和挂起。

  • 处理 Java 程序中的内存漏洞 (developerWorks,2001 年 2 月)中,了解导致 Java 内存泄漏的原因,以及何时需要考虑它们。

  • developerWorks Linux 专区中,可以找到更多为 Linux 开发人员准备的参考资料。

  • 从 developerWorks 的 Speed-start your Linux app 专区中,可以下载运行于 Linux 之上的 IBM 中间件产品的免费测试版本,其中包括 WebSphere® Studio Application Developer、WebSphere Application Server、DB2® Universal Database、Tivoli® Access Manager 和 Tivoli Directory Server,查找 how-to 文章和技术支持。

  • 通过参与 developerWorks blogs 加入到 developerWorks 社区。

  • 可以在 Developer Bookstore Linux 专栏中定购 打折出售的 Linux 书籍
posted on 2006-01-10 10:27 千里马肝 阅读(791) 评论(2)  编辑 收藏

  回复  引用  查看    
2006-01-14 00:33 | 疯子阿虹 [未注册用户]
:)
的确可以很方便的把STL的MEMPOOL代码copy出来然后修改一下。
而且支持多线:)

不过令人不爽的有两个地方
1。不能调用构造/析构,不过这个可以解决。
2。分配数组比较麻烦:(

  回复  引用  查看    
2006-01-15 22:25 | 千里马肝      
我认为作为memory pool应该是系统级做会更好
如果只是object级别,会出现A类对象还有闲置,而B类对象不够了,却没有权限去找A要

所以个人认为使用memory pool的malloc来替换掉crt中的版本会比较好

标题  
姓名  
主页
Email (只有博主才能看到) 
验证码 *  看不清,换一张 [登录][注册]
内容(请不要发表任何与政治相关的内容)  
  登录  使用高级评论  新用户注册  返回页首  恢复上次提交      
该文被作者在 2006-01-13 10:26 编辑过
 
另存  打印
最新IT新闻:
 


<2006年1月>
25262728293031
1234567
891011121314
15161718192021
22232425262728
2930311234

与我联系

常用链接

留言簿(33)

我参与的团队

我的标签

随笔档案(292)

文章档案(1)

好友

搜索

  •  

最新评论

阅读排行榜

评论排行榜