为什么一个物体在推到向量上时会被破坏
Why does an object get destroyed when pushing it to a vector?
我想知道为什么我推回到向量中的元素在这种情况下会调用其析构函数:
#include <iostream>
#include <vector>
class Foo
{
public:
Foo(int a)
: m_a(a)
{
std::cout << "Foo ctor() " << m_a << std::endl;
}
~Foo()
{
std::cout << "Foo dtor() " << m_a << std::endl;
}
private:
int m_a;
};
class FooStorage
{
public:
static void createFoo(int a)
{
m_foos.push_back(Foo(a));
}
static std::vector<Foo> m_foos;
};
std::vector<Foo> FooStorage::m_foos;
int main()
{
std::cout << "Before: " << FooStorage::m_foos.size() << std::endl;
FooStorage::createFoo(53);
std::cout << "After: " << FooStorage::m_foos.size() << std::endl;
return 0;
}
这会打印出以下内容:
Before: 0
Foo ctor() 53
Foo dtor() 53
After: 1
Foo dtor() 53
我想知道:
- 什么会被删除?(位于"Before"answers"After"区域之间)
- 为什么它会被删除
- 向量中的结果是什么
您正在此处创建一个临时对象:
m_foos.push_back(Foo(a));
// ^^^^^^
当完整表达式结束时,该对象的析构函数将被调用,但它将被push_back()
复制(或移动)到向量中。
为了防止创建临时,可以使用emplace_back()
:就地构建
m_foos.emplace_back(a);
m_foos.push_back(Foo(a));
这将导致两个构造函数调用(,但这完全取决于它可以优化的编译器)。
Foo(a)
是一个临时的,它将被构造(一个构造函数调用),然后复制到向量(复制构造函数调用)。像往常一样,临时词一直存在,直到它们被使用的表达结束。因此,当push_back结束时,它将为这个临时调用析构函数(这就是为什么您看到对析构函数的调用)。
相关文章:
- 函数向量_指针有不同的原型,我可以构建一个吗
- C++从另一个类访问公共静态向量的正确方法是什么
- 为什么我不能将一个对象push_back到属于另一个类的对象向量中?
- 给定一个向量,如何找到该向量的所有子集和的原始索引
- 获取向量C++中第一个值和最后一个值的和
- 从多个源构造一个对象,包括一个对象向量
- 为什么一个向量上的多线程操作很慢
- 基于范围的 for 循环:迭代使用一个元素扩展的向量
- C++ - 如何在结构向量中找到结构体一个成员的最大值?
- 如何在 C++11 中查找和更新向量中的一个嵌套结构
- Lower_bound不适用于具有 3 个元素的向量的最后一个元素
- 将一个向量插入另一个向量的某个位置
- std::find,返回所有找到的值的替代方法,而不仅仅是存在重复的向量的第一个值
- 将指向给定子类的指针从一个向量复制到另一个向量
- 如何创建一个类,以便向量工作 std::vector<MyClass<int>> v{ 1,2,3 };
- C++ STD 函数运算符:有没有一种方法可以通过函数将一个向量映射到另一个向量上?
- 将向量之间的数字放在另一个向量之间<vector>>如果两个数字的差值为 1
- 如何在不复制的情况下将一个向量移动到另一个向量中
- 创建一个函数的 Python 绑定,返回指向带有 boost 的向量的指针
- 紧凑向量一个小的内存足迹向量