热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

c++:vector对象的动态增长机制

容器大小管理操作容器大小操作函数c.shrink_to_fit()请将capacity()减小为与size()相同大小c.capacity()不重新分配内存空间的话,
  1. 容器大小管理操作

容器大小操作函数
c.shrink_to_fit()请将capacity()减小为与size()相同大小
c.capacity()不重新分配内存空间的话,c可以保存多少元素
c.reserve(n)分配能容纳至少n个元素的内存空间

shrink_to_fit只适用于vector、string和deque;
capacity和reserve只适用于vector和string
reserve并不改变容器中元素的数量,仅影响vector预先分配多大的内存空间

  1. 一个例子

//空间增长
int main()
{vector<int> ivec;cout << "ivec:size" << ivec.size() << endl << "capaciti:" << ivec.capacity() << endl;for (vector<int>::size_type ix &#61; 0; ix !&#61; 24; &#43;&#43;ix)ivec.push_back(ix);cout << "ivec:size" << ivec.size() << endl << "capaciti:" << ivec.capacity() << endl;ivec.reserve(50);cout << "ivec:size" << ivec.size() << endl << "capaciti:" << ivec.capacity() << endl;while (ivec.size() !&#61; ivec.capacity())ivec.push_back(0);cout << "ivec:size" << ivec.size() << endl << "capaciti:" << ivec.capacity() << endl;ivec.push_back(42);cout << "ivec:size" << ivec.size() << endl << "capaciti:" << ivec.capacity() << endl;ivec.shrink_to_fit();cout << "ivec:size" << ivec.size() << endl << "capaciti:" << ivec.capacity() << endl;return 0;
}

输出结果&#xff1a;

在这里插入图片描述

①可以看到当创建一个空的vector容器后&#xff0c;其中所含的元素和分配的内存均为0&#xff1b;
②当其增长24个元素后&#xff0c;其中所含元素数量为24&#xff0c;而所分配的空间为28&#xff0c;这是依赖于标准库的具体实现决定的&#xff1b;
③手动使用reserve()为其分配50的内存后&#xff0c;其内存变为50&#xff0c;元素数量没有改变&#xff1b;
④之后将size补满至内存空间大小&#xff0c;二者皆为50&#xff1b;
⑤再向容器中增加一个元素后&#xff0c;其内存空间被分配为75&#xff0c;增长了原内存空间的1/2&#xff0c;这是依赖于编译器本身的&#xff1b;
⑥最后应用shrink_to_fit使得内存空间减少为size的大小

了解容器大小操作后可对溢出和预分配等做进一步理解


推荐阅读
author-avatar
恋之-风景-
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有