C++ 中的打印析构函数
Print destructor in c++
我有这个代码。输出为:~A~AprintA~AprintA~AprintA~AprintA~A。我明白为什么它会打印出 printA~AprintA~AprintA~A(因为我有 3 个push_back(,但我不明白为什么"~A"在句子开头出现 3 次。如果我只有v.push_back(a);
(只有这个,没有其他 2 push_backs(,"~A",不会出现,为什么?
#include<vector>
#include<iostream>
class A {
public:
virtual void print() {
std::cout << "printA";
}
virtual ~A() {
std::cout << "~A";
}
};
int main() {
std::vector<A> v;
A a;
A b;
A c;
v.push_back(a);
v.push_back(b);
v.push_back(c);
for (auto e : v)
e.print();
}
当你将对象推回向量时,它的size()
会增加。然后,当通过push_back()
添加足够的对象时(在这种情况下,在初始对象之后只需要 1 个(,并且capacity() < size() + 1
变为 true,向量必须增加容量才能容纳更多元素,这需要重新分配,从而破坏和重构对象,这就是您看到析构函数调用的原因。
尝试在使用reserve(new_cap)
添加到向量之前增加向量的容量,您将看到析构函数调用不会发生:
std::vector<A> v;
v.reserve(10);
A a;
A b;
A c;
//etc..
当您只回推 1 个对象时,不会发生这种情况,因为矢量中不包含必须重新创建的任何东西。
相关文章:
- 什么时候调用组成单元对象的析构函数
- 如果C++类在类方法中具有动态分配,但没有构造函数/析构函数或任何非静态成员,那么它仍然是POD类型吗
- 内联映射初始化的动态atexit析构函数崩溃
- 什么时候调用析构函数
- 优先顺序:智能指针和类析构函数
- C++-明确何时以及如何调用析构函数
- 使用基类指针创建对象时,缺少派生类析构函数
- 在c++中使用向量时,如何调用构造函数和析构函数
- 重载运算符new[]的行为取决于析构函数
- 我需要知道编译器如何在cpp中使用析构函数
- 为什么在使用转换构造函数赋值后调用C++类的析构函数?
- 析构函数调用
- 通过引用传递-为什么要调用这个析构函数
- 对具有动态分配的内存和析构函数的类对象的引用
- 重载 -> shared_ptr 个实例中的箭头运算符<interface>,接口中没有纯虚拟析构函数
- C++成员的析构函数顺序与shared_ptr
- C++ 防止在映射中放置()时调用析构函数
- 如果构造函数和析构函数可以获取和显示(打印)数据,为什么我们需要 getter 和 setter?
- C++ 中的打印析构函数
- 利用构造函数、析构函数和打印对象- c++