Just enjoy programming

一个简单的空间配置器

     以STL的运用角度而言,空间配置器时最不需要介绍的东西,它总是隐藏在一切组件的背后,整个STL的操作对象(所有的数值)都存放在容器之内,而容器一定需要配置空间以置放资料。下面是一个简单空间配置器代码(来自 STL源码剖析):
//jjalloc.h
#ifndef _JJALLOC_
#define _JJALLOC_

#include<new>
#include<cstddef>
#include<cstdlib>
#include<climits>
#include<iostream>

using namespace std;

namespace JJ
{
template<class T>
    inline T* _allocate(ptrdiff_t size,T*)
    {
        set_new_handler(0);
        T *tmp=(T*)(::operator new((size_t)(size* sizeof(T))));
        if(tmp==0){
            cerr<<"out of memory"<<endl;
            exit(1);
        }
        return tmp;
    }

template<class T>
    inline void _deallocate(T* buffer)
    {
        ::operator delete(buffer);
    }

template<class T1,class T2>
    inline void _construct(T1 *p,const T2& value)
    {
        new(p)T1(value);//placement new operator
    }

template<class T>
    inline void _destroy(T* ptr)
    {
        ptr->~T();
    }

template<class T>class allocator{
    public:
        typedef    T    value_type;
        typedef T*    pointer;
        typedef const T*    const_pointer;
        typedef T&    reference;
        typedef const T&    const_reference;
        typedef size_t    size_type;
        typedef ptrdiff_t    difference_type;

        template<class U>
        struct rebind
        {
            typedef allocator<U>other;
        };

        pointer allocate(size_type n,const void * hint=0)
        {
            return _allocate((difference_type)n,(pointer)0);
        }

        void deallocate(pointer p,size_type n)
        {
            _deallocate(p);
        }

        void construct(pointer p,const T& value)
        {
            _construct(p,value);
        }

        void destroy(pointer p){_destroy(p);}

        pointer address(reference x){return (pointer)&x;}

        const_pointer const_address(const_reference x)
        {
            return (const_pointer)&x;
        }

        size_type max_size()const{
            return size_type(UINT_MAX/sizeof(T));
        }
};
}//end of namespace JJ

#endif


//jjalloc.cc,测试上面这个简单的配置器
#include"jjalloc.h"
#include<vector>
#include<iostream>

using namespace std;

int main()
{
    int ia[5]={0,1,2,3,4};
    unsigned int i;

    vector<int,JJ::allocator<int> >iv(ia,ia+5);

    for(i=0;i<iv.size();i++)
        cout<<iv[i]<<' ';
    cout<<endl;
}



posted on 2011-05-04 00:55 周强 阅读(483) 评论(0)  编辑 收藏 引用 所属分类: c++ STL源码分析


只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   博问   Chat2DB   管理