加载中…
个人资料
南冠彤
南冠彤
  • 博客等级:
  • 博客积分:0
  • 博客访问:415,028
  • 关注人气:59
  • 获赠金笔:0支
  • 赠出金笔:0支
  • 荣誉徽章:
相关博文
推荐博文
谁看过这篇博文
加载中…
正文 字体大小:

(转)关注内存 提高软件性能(2)

(2011-06-16 18:25:22)
标签:

杂谈

分类: CPP/C

还有一种就是定义一个基类.里面实现new,delete操作符,然后以后所有的类从该类派生,自动继承基类的new,delete的实现.这种方法容易产生内存碎片.我的代码实现如下.下面的代码还存在很多问题.暂时先放上去吧.

版本3.

#include<iostream>

#include <list>

#include <algorithm>

using namespace std;

class memorypool//该类的实例只允许出现一次.我用到了singleton模式.

{

public:

       static memorypool* Instance()

       {

              if(_instance == 0)

                     _instance = new memorypool;

              return _instance;

       }

       void Add( void * p)

       {

              lpMemlist->push_back(p);

       }

       void Del(const void* p)

       {

              list<void*>::iterator ite = find(lpMemlist->begin(),lpMemlist->end(),p);

              lpMemlist->erase(ite);

       }

       void clear()

      

        list<void*>::iterator it =lpMemlist->begin();

      

        while(!lpMemList->empty())

           delete (*it++);

         

              lpMemlist->clear();

       }

      

       protected:

       memorypool();

private:

       static memorypool* _instance;

       static list<void*>* lpMemlist;//作为池的数据结构

};

memorypool* memorypool::_instance = 0;

list<void*>* memorypool::lpMemlist = 0;

memorypool::memorypool()

{

       lpMemlist = new list<void*>;

      

       cout<<"list now has : " << lpMemlist->size() << endl;

}

 

///////////////////////////////////////////////////////////////////////////////////

class CBase

{

public:

       CBase() {

                    memorypool::Instance();

       }

       void* operator new(size_t size)

       {

              void *p = malloc(size);

              memorypool::Instance()->Add(p);

              return p;

       }

       void operator delete(void* p)

        delete p;

              memorypool::Instance()->Del(p);

       }

       ~CBase() { memorypool::Instance()->clear(); cout<<"base dtor\n";

       }

private:

       //static memorypool*

       //int nLeft;

};

class myclass :public CBase

{

public:

       myclass() { cout << "myclass ctor\n";}

};

class myclass2:public CBase

{

public:

       myclass2() { cout<<"myclass2 ctor\n";}

};

 

void testfun()

     

              myclass* p = new myclass;

              myclass2* p2 =new myclass2;

              memorypool::Instance()->clear();

}

void main()

{

       testfun();

}

上面的几种想法只是我想实现一下所谓的gc,感觉还是智能指针效果最好.其它几个版本我只是想模拟一下,验证我自己的想法而已.代码中肯定有错误的地方.不要被指责得一无是处就好.


本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/loyalzu/archive/2004/05/07/17667.aspx

0

阅读 评论 收藏 转载 喜欢 打印举报/Report
  • 评论加载中,请稍候...
发评论

    发评论

    以上网友发言只代表其个人观点,不代表新浪网的观点或立场。

      

    新浪BLOG意见反馈留言板 电话:4000520066 提示音后按1键(按当地市话标准计费) 欢迎批评指正

    新浪简介 | About Sina | 广告服务 | 联系我们 | 招聘信息 | 网站律师 | SINA English | 会员注册 | 产品答疑

    新浪公司 版权所有