c++ - 如何在不调用析构函数的情况下重新分配 vector ?

标签 c++ class c++11 vector destructor

在这段代码中:

Texture * a = new Texture();
Texture * b = new Texture();
buttons.push_back(*a);
buttons.push_back(*b);

buttons 是这样定义的 vector :

std::vector<Texture> buttons;

Texture 是一个类,这是它的原型(prototype):

class Texture
{
public:
    Picture * texData;
    HitBox * texCoords;
    Texture();
    ~Texture();
    void render_tex();
};

第一个代码块的第 4 行调用了纹理 a 的析构函数。问题是这个析构函数删除了 texDatatexCoords 指向的值,这意味着当它被重新分配时 texDatatexCoords 指向垃圾数据。

有没有办法让vector在重新分配时不调用析构函数?

最佳答案

由于您动态分配数据成员 texDatatexCoords你需要遵循 Rule of Three ,并定义复制构造函数和复制赋值运算符,否则您的代码将很容易被破坏,正如您所发现的那样。

但还有更好的方法!不要使用原始指针作为数据成员。使用 unique_ptr让他们抱起来。 (您可能根本不需要它们作为指针,但我会在这里给您带来疑问的好处)。您仍然需要定义复制构造函数和复制赋值运算符,并手动复制 unique_ptr 中的内容。如果您希望类(class)可复制,请保留。

要使其可移动,您可以显式 =default移动构造函数和移动赋值运算符。


此外,您的代码正在泄漏内存。您动态分配这些对象,然后 push_back 复制vector

Texture * a = new Texture();
buttons.push_back(*a);

您正在取消引用 a并将它的拷贝添加到 vector .除非你delete a;在超出范围之前,您会发生内存泄漏。使用 vector<unique_ptr<Texture>>相反。

vector<unique_ptr<Texture>> buttons;

buttons.push_back(unique_ptr<Texture>(new Texture()));

对于 C++14,您可以使用 make_unique避免不得不 new对象自己

buttons.push_back(make_unique<Texture>());

此外,如果您事先知道要添加的按钮数量,您可以 reserve空间以避免重新分配。

buttons.reserve(num_buttons);

现在,您实际上可能不需要动态分配 Texture对象。您可能需要的只是

vector<Texture> buttons;
buttons.push_back(Texture());

如果可能的话,我还会为 Texture 定义一个移动构造函数和移动赋值运算符。这样它就可以在 vector 重新分配时移动,而不是被复制。

关于c++ - 如何在不调用析构函数的情况下重新分配 vector ?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24191238/

相关文章:

c++ - 有没有办法在 C++ 中将输出生成为列表?

c++ - 类构造函数和对象实例化/初始化 C++/GCC

php - 如何正确设置 PDO 连接

c++ - 我的 g++ 使用 vector<weak_ptr> erase() 方法生成奇怪的警告

c++ - C++11 线程如何包裹 pthreads

c++ - 添加到 vector 的 std::shared_ptr 会导致段错误

c++ - std::vector-like 类优化以容纳少量项目

c++ - 如果可以将其置于私有(private)状态,为什么还要使用 static const (int/string/..)?

c++ - 具有表达式模板的多维数组模板类

c++ - 如果传入 std::swap 的对象在交换期间抛出异常怎么办?