有没有办法防止向量中的元素被破坏
Is there a way to prevent an element in a vector to be destructed?
我有某种类型的向量,我想以某种随机顺序破坏元素,而不移动向量中的其他元素。 稍后,我可能会在那些被破坏的孔中放置新的(或不)。 当我销毁向量时,我不想为已经销毁的元素调用析构函数,那么是否可以这样做,如果是,如何这样做?
我一直在考虑使用 char[sizeof(T)] 作为矢量元素类型,但我看到 std::align_of 和 std::aligned_storage 仅适用于 POD 存储。 那么,如何确保这适用于非 POD 类型?
还有其他方法可以做到这一点吗?
我正在研究MSVS2010,可能很快就会升级到 2013 年。
std::vector<boost::optional<T>> v;
...
v[i] = boost::none; // destroy an object
如果你不能使用boost
,那么实现你自己的optional
类是相当微不足道的。 只需将std::aligned_storage<T>
与指示对象是否有效的bool
一起使用即可。
如果我正确理解您的问题,您可以使用shared_ptrs向量来解决这个问题。如果要删除元素,请将其分配给 nullptr shared_ptr。
使用数组?
Type * a = new Type[BASE_SIZE];
插入时,如果需要扩展,请使用此
Type * tmp = new Type[BIGGER_SIZE];
std::copy(a, a + a.length, temp);
delete[] a;
a = tmp;
删除时,只需替换 NULL 或 w/e,并将其替换为删除标记或 w/e。
相关文章:
- 向量元素的引用地址与它所指向的向量元素的地址不同.为什么
- C++:如何循环通过向量中的整数元素
- 如何在C++向量中奇数元素前面加上值-1,我在使用insert函数时遇到了问题
- 不允许在向量中添加更多元素
- 基于范围的 for 循环:迭代使用一个元素扩展的向量
- 使用并行参数向量调用元素向量的成员函数
- C++ 查找字符串中存在的元素向量
- 包含 std::threads 的元素向量
- 避免从单一元素向量转换为基元类型
- 对自定义元素向量进行排序时出现意外(至少对我来说)行为
- 如何为对元素(向量和int)配对创建unique_ptr也是unique_ptr
- 元素向量乘法 C++(代码不起作用)
- 时间和空间复杂性在二叉树的每个级别创建元素向量(NON-BST)
- 遍历结构元素向量
- 犰狳C++中的元素向量或矩阵乘法
- 为什么'std::vector<int> b{2};'创建 1 元素向量,而不是 2 元素向量?
- 可移动元素向量的大小调整是否有效?
- 唯一元素向量的c++模板函数
- 获取索引和元素-向量问题
- 定义一个生成元素向量的函数时,正确的方法是什么?