说明:本文仅供学习交流,转载请标明出处,欢迎转载!

STL中与内存配置相关的类是allocator类,头文件为:#include<alllocator>这是一个模板类,用于内存的分配、对象的构造、对象的析构和空间的删除。本文主要介绍下相关的函数。

内存空间的分配:allocate函数

 allocate函数原型为:iter allocate(n,T*)。分配足以容纳n个T对象的空间,返回指向所分配空间的首地址

对象的构造:construct函数

 construct函数原型为:void construct(T1 *p,const T& value)。用值value去初始化p所指向的地址。

对象的析构:destroy函数

destroy函数原型为:void destory(T *p),析构p所指向的对象。

内存空间的释放:deallocate函数

   deallocate函数原型为:void deallocate(T *p,size_type n)。将p所指向的n个T类型对象所占用的内存释放掉。

以下的几个函数中。我们用“已知”表示“已经构造”,用“未知”表示“尚未构造”,所谓“未构造”指的是“已分配的空间尚未使用“。

将已知范围的元素拷贝到还有一个未知区域:uninitialized_copy函数

 uninitialized_copy函数原型为:iter uninitialzed_copy(b,e,b1),将迭代器范围[b,e)所指向的元素依次拷贝到[b1,b1+(e-b) )的区域,返回值为iter=b1+(e-b)所指向的空间

将某个值去填充一个未知区域:uninitialized_fill

uninitialized_fill函数原型为:void unitialized_fill(b,e,t)。用值t去填充迭代器范围[b,e)所指向的区域。

用n个同样值去填充某个未知区域:uninitialized_fill_n

uninitialized_fill_n函数原型为:iter uninitialized_fill(b,n,t),用值t去填充迭代器范围[b,b+n)所指向的区域,返回迭代器 b+n

Notice:后三个uninitialized_xxx函数的作用都是用批量初始化一个未知区域(即未使用区域),这三个函数的内部实现中有两个值得注意的地方:

1.严格遵守"commit or rollback"原则。该原则规定,在批量初始化过程中。要么产生全部的必要元素。要么不产生一个元素,即要么不做,做了就做好做全。

        2.在初始化过程中,会先推断待初始化的元素类型是否为内置类型,若为内置类型POD(Plain Old Data),则直接调用更加底层的函数,上面三个函数相应的底层函数分别为:memmove(b1,b,e-b)、fill(b,e,t)和fill(b,n,x)。若数据类型为其它类型,则循环调用construct(iter,t)函数,这样做的目的是为了提高效率。

參考文献:

[1]《C++primer 第4版》

[2]《STL源代码剖析 侯捷》

STL之内存处理的更多相关文章

  1. STL的内存管理

    SGI STL 的内存管理 http://www.cnblogs.com/sld666666/archive/2010/07/01/1769448.html 1. 好多废话 在分析完nginx的内存池 ...

  2. STL之内存处理工具

    STL处理内存主要是使用五个全局函数construct,deconstruct,construct实现: template<typename T1,tyname T2> void cons ...

  3. C++ STL vector 内存分配

    vector为了支持快速的随机访问,vector容器的元素以连续方式存放,每一个元素都紧挨着前一个元素存储. 当vector添加一个元素时,为了满足连续存放这个特性,都需要重新分配空间.拷贝元素.撤销 ...

  4. [转]STL的内存分配器

    题记:内存管理一直是C/C++程序的红灯区.关于内存管理的话题,大致有两类侧重点,一类是内存的正确使用,例如C++中new和delete应该成对出现,用RAII技巧管理内存资源,auto_ptr等方面 ...

  5. STL vector 内存释放

    最近在论坛看到一个提问帖子,问题是vector中存储了对象的指针,调用clear后这些指针如何删除? class Test { public: Test() {} ~Test() { cout < ...

  6. SGI STL中内存池的实现

    最近这两天研究了一下SGI STL中的内存池, 网上对于这一块的讲解很多, 但是要么讲的不完整, 要么讲的不够简单(至少对于我这样的初学者来讲是这样的...), 所以接下来我将把我对于对于SGI ST ...

  7. STL之内存管理

    STL以泛型思维为基础,提供了6大组件:容器(containers).算法(algorithms).迭代器(iterators).仿函数(functors).适配器(adapters).分配器(all ...

  8. 关于 stl的内存分配的深浅拷贝

    http://blog.csdn.net/u012501459/article/details/44132147

  9. C++STL内存管理方法(g++版)

    STL作为C++的经典作品,一直备受人们关注.本文主要介绍STL的内存管理策略. 早期的STL内存管理 第一次接触STL源码是看侯捷先生的<STL源码剖析>,此书通俗易懂,剖析透彻,是极佳 ...

随机推荐

  1. C#异常处理及心得

    C sharp中的异常用于处理系统级和应用程序级的错误状态,它是一种结构化.统一的类型安全的处理机制.c#的异常 机制非常类似于c++的异常处理机制,但是还是有一些重要的区别: 1,在 C# 中,所有 ...

  2. IDEA是如何导入项目的,及启动导入项目遇到的问题:无法加载主类的一连串问题

    1.启动报错误: 找不到或无法加载主类 org.spring.springboot.Application 可能在工程下面有多个module,然后,module里面的iml配置文件不止一个,删除留主的 ...

  3. No configuration found for the specified action解决办法(转)

    使用Struts2,配置一切正常,使用常用tag也正常,但是在使用<s:form>标记时,发现控制台总是输出警告信息, 警告信息内容如下: 警告: No configuration fou ...

  4. 虚拟机下linux迁移造成MAC地址异常处理办法

    虚拟机下linux迁移造成MAC地址异常处理办法 Linux无法启用网卡:Device eth0 has different MAC address than expected,ignoring解决 ...

  5. jdbc第三天

    事务 什么是事务? 转账: 1. 给张三账户减1000元 2. 给李四账户加1000元 当给张三账户减1000元后,抛出了异常!这会怎么样呢?我相信从此之后,张三再也不敢转账了. 使用事务就可以处理这 ...

  6. java两种同步机制的实现 synchronized和reentrantlock

    java两种同步机制的实现 synchronized和reentrantlock 双11加保障过去一周,趁现在有空,写一点硬货,因为在进入阿里之后工作域的原因之前很多java知识点很少用,所以记录一下 ...

  7. PLSQL报错:"动态执行表不可访问,本会话的自动统计被禁止"

      PLSQL报错:"动态执行表不可访问,本会话的自动统计被禁止" CreationTime--2018年7月16日19点26分 Author:Marydon 1.情景展示 2.解 ...

  8. 26、线性表(List)

    1.List List接口是Collection的子接口,List是一个可重复集合 2.ArrayList和LinkedList ArrayList和LinkedList是List接口最常见的两个实现 ...

  9. linux上传下载文件rz,sz

    [一般用于SecureCRT ssh中使用] █ 法一:直接用yum安装lrzsz(推荐) yum install lrzsz -y 注意:rhel安装完系统后 直接可使用 rz sz █ 法二:源文 ...

  10. Linux 系统使用 iso 镜像文件或光盘配置本地YUM 源的最简单方式

    1.分配光驱 选择本地的iso系统镜像文件,或者在光驱中放入系统安装盘.之后,在桌面可以看到RHEL-7.2-Server的光盘图标. 2.查看光驱挂载的位置 使用df -h 命令可以看到光驱或镜像文 ...