C++中清空Vector内元素的方法以及释放内存

这篇具有很好参考价值的文章主要介绍了C++中清空Vector内元素的方法以及释放内存。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

初始化如下:

int i, j;
vector <int> vecInt;
for (int i=0;i<500;i++)
{
    vecInt.push_back(i);
}
// 为什么capacity和size不同,因为要扩容。具体扩容的大小并不一定,此处明显陆续多扩容了12个元素空间
j = vecInt.capacity();  //j=512
i = vecInt.size();      //i=500  

方法一:

使用 clear ,清空元素,但不回收空间

vecInt.clear();
j = vecInt.capacity();  //j=512
i = vecInt.size();      //i=0

方法二:

使用 erase循环删除,结果同上

//std::vector::erase()函数原型:
iterator erase (iterator position); //删除指定位置元素
iterator erase (iterator first, iterator last); //删除指定范围内的元素。
 
vector <int>::iterator iter=vecInt.begin();
for ( ;iter!=vecInt.end();)
{
    iter = vecInt.erase(iter);
}
j = vecInt.capacity();  //j=512
i = vecInt.size();      //i=0       

erase在每次操作时,迭代器指针会整体前移1,就是每次都会“搬”全部数据,所以vector不适合做频繁删除的容器。

方法三:

最简单的使用swap,清除元素并回收内存

vector <int>().swap(vecInt);  //清除容器并最小化它的容量,
//另一种写法
//vecInt.swap(vector<int>()); 
j= vecInt.capacity();  //j=0  
i = vecInt.size();     //i=0        

这个做法意思就是new了一个新的空的vector,然后交换。可以查看如下示例代码理解:

#include<stdio.h>
#include <string.h>
#include <string>
#include<vector>

using namespace std;

int main()
{
  vector<string> v1;
  vector<string> v2;
  
  v1.clear();  v2.clear();
  
  char buffer[21];

  // 加载字符串到容器v1
  for ( int ii=0;ii<3;ii++ )
  {
     memset(buffer,0,sizeof(buffer));
     sprintf(buffer,"v1第%d个字符串。",ii+1);
     v1.push_back(buffer);
  }

  // 加载字符串到容器v2
  for ( int ii=0;ii<3;ii++ )
  {
     memset(buffer,0,sizeof(buffer));
     sprintf(buffer,"v2第%d个字符串。",ii+1);
     v2.push_back(buffer);
  }

  // swap 前
  printf("swap前:\n");
  for( int ii=0;ii<3;ii++)  {  printf("v1的第%d个元素:%s\n",ii+1,v1[ii].c_str()); };
  for( int ii=0;ii<3;ii++)  {  printf("v2的第%d个元素:%s\n",ii+1,v2[ii].c_str()); };

  v1.swap(v2);

  // swap 后
  printf("swap后:\n");
  for( int ii=0;ii<3;ii++)  {  printf("v1的第%d个元素:%s\n",ii+1,v1[ii].c_str()); };
  for( int ii=0;ii<3;ii++)  {  printf("v2的第%d个元素:%s\n",ii+1,v2[ii].c_str()); };

  return 0;
}

输出结果:文章来源地址https://www.toymoban.com/news/detail-595082.html

swqp前:
v1的第1个元素:v1第1个字符串。
v1的第2个元素:v1第2个字符串。
v1的第3个元素:v1第3个字符串。
v2的第1个元素:v2第1个字符串。
v2的第2个元素:v2第2个字符串。
v2的第3个元素:v2第3个字符串。
swap后:
v1的第1个元素:v2第1个字符串。
v1的第2个元素:v2第2个字符串。
v1的第3个元素:v2第3个字符串。
v2的第1个元素:v1第1个字符串。
v2的第2个元素:v1第2个字符串。
v2的第3个元素:v1第3个字符串。

到了这里,关于C++中清空Vector内元素的方法以及释放内存的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • C++:vector使用以及模拟实现

    和我们原来讲的string不同, vector并不是类,是一个类模板,加类型实例化以后才是类。 vector是表示 可变大小数组 的序列容器。 像数组一样 ,vector也采用的连续存储空间来存储元素,但是容量可以动态改变。 和其它容器相比,vector访问元素、尾插、尾删较高效,但不在尾部

    2024年02月11日
    浏览(43)
  • C++(20):vector通过erase,erase_if删除符合条件的元素

    C++20前,vector可以通过成员函数erase删除迭代器指定的元素,并返回被删除的下一个元素:  1.通过迭代器删除指定位置元素 需要说明的是,删除元素后,迭代器会失效,可以通过erase返回下一个有效的迭代器

    2024年01月16日
    浏览(42)
  • 【C++】vector的使用 以及 迭代器失效问题

    前言 经过前面string的学习,我们已经掌握了许多string的类函数,vector中许多类函数与string中的类函数使用起来相似,例如迭代器的使用在所有的容器中使用都一样,这里我们不再介绍,下面我们学习一些vector类的一些常用的函数。 1.vector的文档介绍 2. vector在C++中表示可变大

    2023年04月24日
    浏览(42)
  • [C++历练之路]vector的介绍以及底层模拟实现

    W...Y的主页 😊 代码仓库分享 💕 🍔前言: 我们学习了STL中的string以及其所有重要接口并进行了模拟实现,但是STL中包含的内容不止于此。学习了string之后继续学习STL中的vector,学习成本会大大降低,因为他们非现类似,现在就让我们进入vector的世界中吧! 目录 vector的介绍

    2024年02月04日
    浏览(47)
  • 【C++】-vector的模拟实现(以及memcpy如何使用)

    💖作者:小树苗渴望变成参天大树🎈 🎉作者宣言:认真写好每一篇博客💤 🎊作者gitee:gitee✨ 💞作者专栏:C语言,数据结构初阶,Linux,C++ 动态规划算法🎄 如 果 你 喜 欢 作 者 的 文 章 ,就 给 作 者 点 点 关 注 吧! 今天来带大家看看vector的模拟实现,思路来说还是比较简

    2024年02月17日
    浏览(42)
  • C++ 什么时候使用 vector、list、以及 deque?

    什么时候使用 vector、list、以及 deque? 如果需要高效地快速访问(随即存取),并且不在乎插入和删除的效率,使用 vector 如果需要大量的插入和删除,而且不关心快速访问 (随即存取) ,使用 list 如果需要快速访问(随即存取) ,并且关心两端数据插入和删除,使用 deque 推荐一个零

    2024年02月10日
    浏览(36)
  • 【C++】容器篇(一)—— vector 的基本概述以及模拟实现

    前言: 在之前,我们已经对 string类进行了基本的概述,并且手动的实现了string类中常用的接口函数。本期,我将带领大家学习的是STL库中的一个容器 -- vector 的学习。相比于之前的string类,本期的 vector 相对来说实现起来略微难一点,难点就在于要考虑关于 “ 迭代器失效 ”

    2024年02月07日
    浏览(45)
  • 【C++】链表(list)的使用以及与vector的区别

    在 C++ 中, std::list 是标准库提供的一个容器类,用于将数据进行链式存储。 链表 (list)是一种物理存储单元上非连续的存储结构,数据元素的逻辑顺序是通过链表中的指针链接实现的。 链表的组成:链表由一系列 结点 组成。 结点的组成:1.存储数据元素的 数据域 2.存储

    2024年02月06日
    浏览(44)
  • 【C++进阶(二)】STL大法--vector的深度剖析以及模拟实现

    💓博主CSDN主页:杭电码农-NEO💓   ⏩专栏分类:C++从入门到精通⏪   🚚代码仓库:NEO的学习日记🚚   🌹关注我🫵带你学习C++   🔝🔝 和string的学习不同 vector即要掌握它的用法 更要会自己去实现一个vector 本章重点: 熟悉STL库中vector的接口函数 自己实现一个简易vector类 本

    2024年02月11日
    浏览(39)
  • 【C++ STL容器】:vector存放数据以及存放自定义的数据类型

    时不可以苟遇,道不可以虚行。 STL 中最常用的容器为: vector ,暂且把它理解为我们之前学过的数组 Array 。 添加头文件: #include vector 利用内置函数: push_back() 先声明两个迭代器, 一个指向容器中的第一元素 , 一个指向容器中的最后一个元素的下一个位置 然后利用一层

    2024年02月15日
    浏览(55)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包