C++ STL中式如何进行内存管理的

标准模板库中对于内存的申请与释放的设计是比较简单的,我们拿std::vector来讲:

  template<typename _Tp, typename _Alloc = std::allocator<_Tp> >
    class vector : protected _Vector_base<_Tp, _Alloc>
    {
    	//...
    }

除了元素的类型外,默认会有一个标准的容器空间配置器std::allocator,我们在使用的vector时往往不会去理会这个参数的,使用的都是默认值。接下来介绍一个该类模板的几个方法:

template<typename T>
struct Allocator{
    T*allocate(size_t size){
        return (T*)malloc(sizeof(T)*size);
    }
    void deallocate(void *p){
        free(p);
    }
    void construct(T*p,const T&val){
        new (p) T(val);
    }
    void construct(T*p,T&&val){
        new (p) T(std::move(val));
    }
    void destroy(T*p){
        p->~T();
    }
};
  1. allocate(size_t size): 为容器开辟空间,使用的是C库函数,malloc();
  2. deallocate(void *p): 是否对象所占用的空间,使用的自然是free(),参数p是对象的地址;
  3. construct(T*p,T&&val) | construct(T*p,T&val) :用来在申请好的内存上调用构造函数来构造对象;
  4. destroy(T*p): 调用析构函数来析构p指向的对象。

实际上,malloc()和free()在linux上的实现也比较复杂,比如对应的ptmalloc版,还有其他tcmalloc,以及jemalloc等,都是比较好的内存池的实现。

接下来,会记录更新学习SGI-STL版本中的内存管理机制。

实现带有自定义空间配置器的vector

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值