一起来读书102- stl源码剖析:第二章 空间配置器

文件结构:

    allocator必须定义于:<memory>

    <memory> 包含以下头文件定义:

        <stl_construct.h>: 定义全局函数construct()和destroy(),负责对象的构造和析构

        <stl_alloc.h>: 定义一,二级allocator;配置器名为alloc

        <stl_uninitialized.h>: 定义了一些全局函数用来填充和赋值大块内存数据,实现STL标准规范:

            un_initialized_copy(), un_initialized_fill(), un_initialized_fill_n()

 

空间的配置与释放: std::alloc

    一二级分配机制:

        一级allocator: __malloc_alloc_template

            allocate()直接使用malloc(), dealloc()直接使用free(),模拟c++的set_new_handler()用来处理内存不足;

        二级allocator: __default_alloc_template

            维护16个自由链表,负责16种小型区块的次配置能以;内存池以malloc()配置而得,如果内存不足,

            转而调用第一级配置器;如果需求区块>128bytes,转而调用第一级配置器;

 

内存基本处理工具:

    1.ForwardIterator uninitialized_copy(InputIterator first, InputIterator last, ForwardIterator result): 

            first:指向输入端的起始位置; last:指向输入端的结束位置; result:指向输出端;

        如果作为输出目的地的[result, result+(last-first))范围内的每一个迭代器都指向未初始化区域,

        则uninitialized_copy()会使用copy constructor,给身为输入来源之[first, last)范围内的每一个对象

        产生一份复制品,放进输出范围中;

    2.void uninitialized_fill(ForwardIterator first, ForwardIterator last, const T& x): 

            first:指向欲初始化空间的起始位置; last:指向欲初始化空间的结束处; x:初始化值

        如果[first, last)范围内的每个迭代器都指向未初始化的内存,那么uninitialized_fill()会在该范围内产生x的复制品;

    3.ForwardIterator uninitialized_fill_n(ForwardIterator first, Size n, const T& x);

            first:指向欲初始化空间的起始位置; n:欲初始化空间的大小; x:初始化值

        如果[first, first+n)范围内的每一个迭代器都指向未初始化的内存,那么uninitialized_fill_n()会调用copy constructor,

        在该范围内产生x的复制品;

        

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值