Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1876200
  • 博文数量: 473
  • 博客积分: 13997
  • 博客等级: 上将
  • 技术积分: 5953
  • 用 户 组: 普通用户
  • 注册时间: 2010-01-22 11:52
文章分类

全部博文(473)

文章存档

2014年(8)

2013年(38)

2012年(95)

2011年(181)

2010年(151)

分类: LINUX

2012-02-20 17:03:20

#include "stdafx.h"
#include
#include
#include
using namespace std;

#pragma comment(lib, "winmm.lib")

template
class MemoryPool
{
public:
    MemoryPool(size_t size = EXPAND_SIZE);
    ~MemoryPool();
    inline void* alloc(size_t size); //分配一个T类型的对象
    inline void  free(void* doomed); //释放一个T类型的指针

//private:
    enum {EXPAND_SIZE = 3};
    MemoryPool* pNext;

    void ExpandFreeList(size_t num = EXPAND_SIZE);
};

template
MemoryPool::MemoryPool(size_t size = EXPAND_SIZE)
{
    ExpandFreeList(size);
}

template
MemoryPool::~MemoryPool()
{
    if (pNext != 0)
    {
        MemoryPool* ptr = pNext;
        for (; ptr != NULL; ptr = pNext)   
        {
            pNext = pNext->pNext;
            delete []ptr;
        }
    }
}

template
inline void* MemoryPool::alloc(size_t size)
{
    if (pNext == 0)
    {
        ExpandFreeList(EXPAND_SIZE);
    }

    MemoryPool* ptr = pNext;
    pNext = pNext->pNext;
    return ptr;
}

template
inline void MemoryPool::free(void* doomed)
{
    MemoryPool* ptr = static_cast* >(doomed);
    ptr->pNext = pNext;
    pNext = ptr;
}

template
void MemoryPool::ExpandFreeList(size_t num /* = EXPAND_SIZE */)
{
    size_t size = sizeof(T) > sizeof(MemoryPool*) ? sizeof(T) :  sizeof(MemoryPool*);
    MemoryPool* ptr = (MemoryPool*)(new char[size]);
    pNext = ptr;
    for (int i=0; i    {
        ptr->pNext = (MemoryPool*)(new char[size]);
        ptr = ptr->pNext;
    }

    ptr->pNext = 0;
}

class Foo2
{
public:
    Foo2(int a = 0, int b = 0):m(a), n(b) {}
    void* operator new (size_t size) {return pool->alloc(size);}
    void operator delete (void* doomed) {return pool->free(doomed);}

    static void NewMemoryPool() { pool =  new MemoryPool;}
    static void FreeMemoryPool()
    {
        if (pool)
        {
            delete pool;
        }
    }

private:
    int m;
    int n;

    static MemoryPool* pool;
};

MemoryPool* Foo2::pool = 0;

class Foo
{
public:
    Foo(int a = 0, int b = 0):m(a), n(b) {}

private:
    int m;
    int n;
};

int main()
{
    DWORD time1, time2, deltaTime;
    time1 = timeGetTime();
    for (int i=0; i<500; ++i)
    {
        Foo* ptrArray[1000];
        for (int j=0; j<1000; ++j)
        {
            ptrArray[j] = new Foo;
        }

        for (int j=0; j<1000; ++j)
        {
            delete ptrArray[j];
        }
    }

    time2 = timeGetTime();
    deltaTime = time2- time1;
    cout<
    Foo2::NewMemoryPool();
    time1 = timeGetTime();
    for (int i=0; i<500; ++i)
    {
        Foo2* ptrArray[1000];
        for (int j=0; j<1000; ++j)
        {
            ptrArray[j] = new Foo2;
        }

        for (int j=0; j<1000; ++j)
        {
            delete ptrArray[j];
        }
    }

    time2 = timeGetTime();
    deltaTime = time2- time1;
    Foo2::FreeMemoryPool();
    cout<
    return 0;
}
阅读(930) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~