是否将std矢量重新分配到默认的构造函数向量是擦除的好方法
Is reassigning a std vector to default constructor vector a good way to erase?
关于清除std::vector
的问题和答案很多,我想知道为什么在我读过的所有内容中,没有人只是说:
existingVector = std::vector<whatever>();
这不是清除向量的简单方法?
分配是可以的,但是可以允许优化实现来保留原始内存缓冲区,以避免重新分配。
有力释放向量的传统智慧是"与临时交换":
#include <vector>
#include <iostream>
int main() {
std::vector<int> a(256);
std::vector<int>().swap(a);
std::cout << a.size() << " / " << a.capacity();
return 0;
}
上面的始终打印 0 / <minimum_capacity_for_vec_impl>
,因为向量必须交换其内部缓冲区。然后立即摧毁临时性,与记忆一起释放。
<minimum_capacity_for_vec_impl>
will 通常为0,因为默认的构造函数为 noexcept
,并且通过这种优点,shuold不做动态内存分配。但是图书馆实施者有时会通过优化具有创造力。
确实很简单,但是有一种更简单,更简单的方式:
existingVector.clear();
您也可以做:
existingVector.resize(0);
,但我喜欢第一种方法,因为它确实做了它所说的。
同样,我更喜欢检查if(myVec.empty())
而不是if(myVec.size() == 0)
更新:如果您想要一个" true Reset",即,您不仅希望大小变为0,而且要容纳的容量,那么您可以做几件事。
收缩以适合
vec.clear(); vec.shrink_to_fit();
当评论正确指出的那样,shillink_to_fit也是一个非结合请求,编译器可能会忽略。
与新构造的向量交换
vector<whatever>().swap(vec);
相关文章:
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 初始化具有非默认构造函数的std::数组项的更好方法
- 具有默认模板类型的默认构造函数的类型推导
- 如何使用非默认构造函数实例化模板化类
- 为什么不调用移动构造函数?(默认情况下只有构造器,没有别的)
- 有没有一种代码密度较低的方法来使用非默认构造函数初始化数组?
- 声明没有默认构造函数的字段
- 基类中的默认析构函数禁用子类中的移动构造函数(如果有成员)
- 没有默认构造函数作为模板参数的自定义比较器
- C++17 没有默认构造函数的地图放置(私有默认构造函数)
- 使用移动调用对等构造函数unique_ptr默认构造函数
- C++复制构造函数和默认构造函数
- 将向量从 N1 缩小到 N2 项,而不触发默认构造函数并仅使用 move 语义
- 构造函数默认公共和私有变量
- 类模板构造函数默认参数
- 构造函数默认参数
- C++模板构造函数默认参数
- 在c++中设置构造函数默认值
- c++构造函数默认参数
- C++构造函数默认值头文件