青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

基于ACE實現的一個內存池-續篇

針對上篇文章《基于ACE實現的一個內存池 》,今天我進行了改版,實之更加方便和合理,代碼如下:
// MemPoolT.h
/**
 *    @date 2007.10.25
 *  @author PeakGao <peakgao163@163.com>
 
*/

 #ifndef OM_MEMPOOLT_H
#define OM_MEMPOOLT_H

#include 
<assert.h>
#include 
<ace/guard_t.h>
#include 
<ace/global_macros.h>

namespace om{

    
/**
        緩沖池

        緩存池采取2維內存緩沖機制,每次new出一個緩沖鏈,每個緩沖鏈為
        <GrowBlockCount>個大小為<BlockSize>的內存塊,緩沖鏈之間建立鏈表關
        系。

        優點:
        1、緩沖池大小由小變大,動態增長,不是一開始就分配一個超大的內
        存,真正按需分配;
        2、不存在realloc,緩沖地址固定不變;
        3、支持FreeList,高效;

        缺點:
        1、分配的對象在長時間不用時沒有實現智能釋放,以后有需要再改

        要求:
        1、每個塊的大小必須大于等于sizeof(Node),32位系統上面是4字節

        示例:
        @code
        class MyObj
        {
        public:
            MyObj()
            {
                std_out<<ACE_TEXT("MyObj::MyObj()")<<std_endl;
            }
            ~MyObj()
            {
                std_out<<ACE_TEXT("MyObj::~MyObj()")<<std_endl;
            }
            void foo()
            {
                std_out<<ACE_TEXT("MyObj::foo()")<<std_endl;
            }
            int dummy; 
        };

        void test()
        {
            using namespace om;
            typedef CachePoolWithLock<ACE_Lock_Adapter<ACE_SYNCH_MUTEX> >            CachePool_Lock;

            CachePool p1;
            p1.create(1024, 256);
            void* pp1 = p1.alloc();
            p1.free(pp1);
            p1.clear();

            CachePool_Lock p2(7, 256);
            void* pp2 = p2.alloc();
            p2.free(pp2);
            p2.clear();


            ObjectPool<MyObj, CachePool_Lock>    pool(128);
            MyObj* o = pool.alloc();
            o->foo();
            pool.free(o);
            pool.clear();
        }
        @endcode
    
*/


    
#define BYTE_ALIGN_8    /// 是否支持塊尺寸8字節對齊的開關宏


    
/**
        緩存池
        這里只實現邏輯,不考慮線程安全,線程安全的版本見下面的CachePoolWithLock模版
    
*/

    
class CachePool
    
{
    
protected:

        
/// 緩沖鏈: Head + cache1 + cache2 + cacheN (N=BlockCount)
        struct Chain
        
{
            Chain
* _Next;

            
void* data() return this + 1; }

            inline 
static Chain* create(Chain*& head, size_t blockSize, size_t blockCount)
            
{
#if defined(BYTE_ALIGN_8)
                blockSize 
= blockSize ? ((blockSize + 7& ~7) : 8// 8字節對齊
#endif
                Chain
* p = (Chain*new char[sizeof(Chain) + blockCount * blockSize];

                p
->_Next = head;
                
return head = p;
            }


            
void free()
            
{
                Chain
* p = this;
                
while (p)
                
{
                    
char* buf = (char*)p;
                    Chain
* next = p->_Next;
                    delete[] buf;
                    p 
= next;
                }

            }

        }
;


        
/// 空閑對象節點,僅僅在空閑對象中有效
        struct Node
        
{
            Node
* _Next;
        }
;


        size_t    _BlockSize;            
/// 數據塊的字節大小
        size_t    _GrowBlockCount;    /// 每次連續分配的塊數
        Chain*    _ChainList;            /// 每次分配的緩沖鏈
        Node*    _FreeNode;            /// 當前空閑節點

    
public:
        
/// 默認構造,注意必須調用create方法初始化參數
        CachePool()
            : _BlockSize(
0), _GrowBlockCount(0), _ChainList(0), _FreeNode(0)
        
{
        }


        CachePool(size_t blockSize, size_t growBlockCount)
            : _ChainList(
0), _FreeNode(0)
        
{
            create(blockSize, growBlockCount);
        }


        
~CachePool()
        
{
            clear();
        }


        
/// 清除所有的內存空間
        void clear()
        
{
            
if (_ChainList)
            
{
                _ChainList
->free();
                _ChainList 
= 0;
                _FreeNode 
= 0;
            }

        }


        
/// 初始化參數
        void create(size_t blockSize, size_t growBlockCount)
        
{
            _BlockSize 
= blockSize;
            _GrowBlockCount 
= growBlockCount;

            assert(_GrowBlockCount 
>= 1);
            assert(_BlockSize 
>= sizeof(Node));
        }


        
/// 獲取塊的大小
        size_t getBlockSize() const
        
{
            
return _BlockSize;
        }


        
/// 獲取連續分配的塊的數目
        size_t getGrowBlockCount() const
        
{
            
return _GrowBlockCount;
        }


        
/// 分配一個塊內存
        void* alloc()
        
{
            assert(_GrowBlockCount 
>= 1);
            assert(_BlockSize 
>= sizeof(Node));

            
if (_FreeNode == 0)
            
{
                
// 分配另一個數據鏈
                Chain* newChain = Chain::create(_ChainList, _BlockSize, _GrowBlockCount);

                Node
* node = (Node*)newChain->data();

                
// 定位到最后一個節點
                (char*&)node += _BlockSize * (_GrowBlockCount - 1);

                
// 建立連接關系
                for (int i=(int)_GrowBlockCount-1; i>=0; i--, (char*&)node -= _BlockSize)
                
{
                    node
->_Next = _FreeNode;
                    _FreeNode 
= node;
                }

            }


            assert(_FreeNode 
!= 0);

            
void* block = (void*)_FreeNode;
            _FreeNode 
= _FreeNode->_Next;

            
return block;
        }


        
/// 釋放塊內存
        void free(void* block)
        
{
            
if (block != 0)
            
{
                Node
* node = (Node*)block;
                node
->_Next = _FreeNode;
                _FreeNode 
= node;
            }

        }

    }
;




    
/*
        支持鎖策略的緩存池,目前用的ACE的鎖,可以很方便的改為其他的鎖策略
        比如_ACELOCK可以為鎖對象ACE_Lock_Adapter<ACE_SYNCH_MUTEX>,也可以
        直接用互斥體如ACE_SYNCH_NULL_MUTEX
    
*/

    template
<class ACELOCK>
    
class CachePoolWithLock : public CachePool
    
{
    
protected:
        ACELOCK        _Lock;            
/// 鎖

    
public:
        CachePoolWithLock()
        
{
        }


        CachePoolWithLock(size_t blockSize, size_t growBlockCount)
            : CachePool(blockSize, growBlockCount)
        
{
        }


        
/// 清除所有的內存空間
        void clear()
        
{
            ACE_GUARD(ACELOCK, ace_mon, _Lock);
            CachePool::clear();
        }


        
/// 分配一個塊內存
        void* alloc()
        
{
            ACE_GUARD_RETURN(ACELOCK, ace_mon, _Lock, NULL);
            
return CachePool::alloc();
        }


        
/// 釋放塊內存
        void free(void* block)
        
{
            ACE_GUARD(ACELOCK, ace_mon, _Lock);
            CachePool::free(block);
        }

    }
;

    
/**
        對象池
        在緩沖池的基礎上,增加了對象的構造和析構為了更好擴充,模版參數直接傳入緩沖池類型,可
        以是上面的CachePool、CachePoolWithLock,也可以是用戶自定義的緩沖池,但必須符合調用規范
    
*/

    template
<class T, class CachePoolStrategy>
    
class ObjectPool : public CachePoolStrategy
    
{
    
protected:
        typedef CachePoolStrategy _Base;

    
public:
        ObjectPool()
        
{
        }


        ObjectPool(size_t growBlockCount)
            : _Base(
sizeof(T), growBlockCount)
        
{
        }


        
/// 初始化參數
        void create(size_t growBlockCount)
        
{
            _Base::create(
sizeof(T), growBlockCount);
        }


        
/// 創建對象的內存空間,但是沒有進行構造,用戶可以自行進行定制的構造
        T* alloc()
        
{
            
void* obj = _Base::alloc();
            ::
new (obj) T(); // 只提供了采用默認構造的方式
            return (T*)obj;
        }


        
/// 釋放對象
        void free(T* obj)
        
{
            
if (obj != 0)
            
{
                obj
->~T();
                _Base::free(obj);
            }

        }

    }
;

}
 // namespace om

#endif // OM_MEMPOOLT_H

posted on 2007-10-29 12:43 PeakGao 閱讀(2732) 評論(2)  編輯 收藏 引用 所屬分類: C++技術

評論

# re: 基于ACE實現的一個內存池-續篇 2008-02-21 08:53 感恩的心

good  回復  更多評論   

# re: 基于ACE實現的一個內存池-續篇 2009-05-08 23:33 imdavid

沒看出來和其他的mmpl 有什么不同, 請作者講下.

好一點的都是自己實現malloc/free, 然后+上HASH LIST 和 鏈表管理。

  回復  更多評論   

<2007年3月>
25262728123
45678910
11121314151617
18192021222324
25262728293031
1234567

導航

統計

常用鏈接

留言簿(9)

隨筆分類(67)

隨筆檔案(65)

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产欧美在线看| 亚洲一区二区三区高清| 亚洲美女尤物影院| 亚洲三级国产| 99日韩精品| 亚洲欧美日韩一区二区在线| 午夜精品福利在线| 亚洲欧美日韩直播| 久久久久99| 亚洲黄色成人网| 一区二区三区精品在线| 欧美一区二区在线播放| 欧美亚洲一级| 亚洲国产精品成人| 一区二区欧美精品| 久久成人免费网| 欧美激情一区二区三区在线| 99re热这里只有精品视频| 欧美一级播放| 欧美日韩精品免费 | 欧美成人高清| 国产精品草草| 亚洲国产精品精华液网站| 亚洲亚洲精品三区日韩精品在线视频 | 国产精品sm| 亚洲第一精品夜夜躁人人躁 | 亚洲一区二区三| 免费看的黄色欧美网站| 亚洲影院在线观看| 欧美日韩国产黄| 亚洲国产第一| 久久精品国产一区二区三区| 日韩视频第一页| 欧美大尺度在线观看| 狠狠色伊人亚洲综合网站色| 亚洲制服欧美中文字幕中文字幕| 免费一区视频| 欧美一区二区三区精品电影| 欧美三级不卡| 亚洲人成啪啪网站| 噜噜噜91成人网| 欧美一区二区三区视频在线观看| 欧美午夜不卡视频| 亚洲免费久久| 亚洲日本成人| 欧美福利一区二区| 亚洲国产成人tv| 免费观看国产成人| 久久综合九九| 亚洲丰满少妇videoshd| 老巨人导航500精品| 欧美自拍丝袜亚洲| 国产在线高清精品| 久久精品国产一区二区三区免费看| 一本色道久久综合亚洲精品高清| 欧美国产精品久久| 亚洲国产精品成人综合| 免费成人性网站| 久久久噜噜噜久久狠狠50岁| 狠狠色狠狠色综合| 久久婷婷成人综合色| 久久国产精品久久久| 国产在线观看一区| 美女黄网久久| 久久人人爽人人爽爽久久| 欧美**人妖| 久久久久久久久岛国免费| 亚洲视频一起| 国产精品欧美久久久久无广告| 夜夜嗨av一区二区三区| 亚洲精品一区二| 欧美日韩精品一本二本三本| 国产精品99久久久久久人| 一区二区三欧美| 国产欧美一区二区三区在线看蜜臀 | 亚洲国产成人久久综合一区| 亚洲一区二区三区精品视频| 国产精品午夜春色av| 欧美中文字幕精品| 欧美亚洲综合在线| 亚洲高清二区| 亚洲最快最全在线视频| 欧美午夜一区二区| 久久国产欧美日韩精品| 美国成人直播| 亚洲欧美日韩精品久久久| 亚洲欧美日韩精品久久奇米色影视| 国产一区导航| 亚洲欧洲在线看| 国产美女搞久久| 老司机成人在线视频| 欧美福利专区| 久久久精品2019中文字幕神马| 久久日韩粉嫩一区二区三区| av成人免费观看| 久久黄金**| 亚洲欧美高清| 欧美国产日韩一区二区| 久久精品亚洲乱码伦伦中文| 欧美精品xxxxbbbb| 久久精品国产2020观看福利| 欧美另类亚洲| 欧美暴力喷水在线| 国产精品自拍三区| 亚洲人成人一区二区在线观看| 国产一区二区久久| 亚洲人成啪啪网站| 国内外成人在线| 99国产精品国产精品久久| 国产综合在线看| 亚洲午夜精品17c| 99成人免费视频| 久热精品在线视频| 欧美一区二区三区免费观看| 欧美日韩成人在线| 麻豆亚洲精品| 国产一区自拍视频| 午夜精品久久久久| 午夜亚洲一区| 国产精品高清在线观看| 亚洲电影av在线| 欧美伊人久久久久久午夜久久久久| 欧美日韩一本到| 亚洲高清视频一区| 伊人一区二区三区久久精品| 亚洲欧美激情四射在线日 | 亚洲一区二区少妇| 欧美国产在线观看| 欧美国产第一页| 136国产福利精品导航网址应用| 亚洲一区免费| 亚洲欧美日韩在线观看a三区| 欧美日本一区二区视频在线观看 | 欧美成人在线网站| 狠狠综合久久av一区二区老牛| 午夜激情综合网| 欧美一区二区视频网站| 国产精品theporn| 亚洲精品一区二区三区99| 一区二区三区视频免费在线观看| 欧美国产综合视频| 日韩视频免费看| 亚洲欧美日本国产专区一区| 国产精品你懂的在线欣赏| 欧美一二三区在线观看| 久久免费视频这里只有精品| 依依成人综合视频| 欧美大片一区二区三区| 99精品国产在热久久下载| 亚洲男人的天堂在线观看| 国产日韩在线视频| 巨乳诱惑日韩免费av| 最新成人av网站| 午夜精品福利视频| 国语自产精品视频在线看一大j8| 久久久久久久999| 最新日韩中文字幕| 欧美一区二区三区喷汁尤物| 黄网站免费久久| 欧美激情黄色片| 欧美一级大片在线免费观看| 欧美插天视频在线播放| 亚洲一区二区精品在线观看| 国产欧亚日韩视频| 美女网站久久| 国产精品99久久久久久久vr| 久久夜色精品国产欧美乱| 99re热这里只有精品视频| 国产午夜精品一区二区三区欧美 | 国产区在线观看成人精品| 久久免费黄色| 宅男噜噜噜66一区二区66| 麻豆精品在线播放| 国产精品99久久久久久久久久久久| 国产喷白浆一区二区三区| 欧美福利电影网| 欧美一级日韩一级| 亚洲精品中文字幕女同| 久久久噜噜噜久久人人看| 一二美女精品欧洲| 激情综合亚洲| 一区二区在线观看视频| 91久久国产综合久久91精品网站| 欧美日韩精品一区二区三区四区 | 欧美成人免费在线| 亚洲丝袜av一区| 精品动漫一区| 国产欧美日韩视频一区二区三区| 另类尿喷潮videofree| 亚洲男女毛片无遮挡| 91久久精品美女高潮| 老司机亚洲精品| 久久福利电影| 午夜亚洲激情| 亚洲在线中文字幕| 亚洲天堂免费观看| 99国产精品久久久久久久久久| 伊人久久大香线| 国产综合色在线视频区| 国产欧美综合在线|