STL 向量插入 - 复制构造函数
STL vector insert - copy constructors
class B
{
private:
int _x;
public:
int get(){return _x;};
B(int x=10):_x(x){cout<<"Default constructor "<<endl;}
~B(){cout<<"destructor "<<endl;}
B(const B &rhs){cout<<"copy constructor"<<endl;}
B& operator =(const B &rhs){cout<<"copy assignment operator"<<endl;}
int operator *(){cout<<"operator *"<<endl;return _x;}
};
int main()
{
vector<B> v;
int i;
vector<B>::iterator ii=v.begin();
for(i=0;i<1;i++)
{
v.push_back(*(new B(i*100)));
}
ii = v.begin();
cout<<"#####################"<<endl;
ii = v.insert(ii+1,*(new B()));
cout<<"#####################"<<endl;
return 0;
}
输出:
Default constructor
copy constructor
#####################
Default constructor
1. copy constructor
2. copy constructor
destructor
#####################
destructor
destructor
为什么在 v.insert(ii,*(new B((((;,两个复制构造函数被称为 ??
首先,您有内存泄漏,因为您不会删除从new
中分配的内存。做你想做的事情的正确方法是v.push_back(B(100));
。
关于为什么复制 ctor 被调用两次,看起来在第二次插入时矢量已经达到其容量并且正在重新分配。在此重新分配期间,它将以前插入的元素复制到新分配的内存中。因此,您会看到复制 ctor 被调用两次。
一个更糟糕的问题是*(new B())
是内存泄漏 - 你复制一个动态分配的对象,然后扔掉指向它的唯一指针。您应该改为创建一个临时对象:
v.insert(ii+1, B());
回答这个问题:由于向量存储为连续的内存块,因此有时需要随着它们的增长而增加容量。发生这种情况时,必须将数组中的所有对象复制(或移动(到其新位置。因此,在这里您会看到一个副本用于移动现有元素,另一个副本用于插入新元素。
相关文章:
- C++17复制构造函数,在std::unordereded_map上进行深度复制
- 为什么在C++中使用私有复制构造函数与删除复制构造函数
- 当从函数参数中的临时值调用复制构造函数时
- 如果有一个模板构造函数只有一个泛型参数,为什么我必须有一个复制构造函数
- 为什么需要复制构造函数,在哪些情况下它们非常有用
- 使用仅使用一次的变量调用的复制构造函数.这可能是通过调用move构造函数进行编译器优化的情况吗
- 为什么类中的ostringstream类型的成员会导致";调用隐含删除复制构造函数";错误
- 复制构造函数、赋值运算符C++
- std::ofstream 作为类成员删除复制构造函数?
- 复制构造函数C++无法正确复制指针
- 关于复制构造函数的一个棘手问题
- 为什么调用复制构造函数而不是移动构造函数?
- 填充上编译器生成的复制构造函数之间的不一致
- C++ 对象指针数组的复制构造函数
- C++ 基本 CTOR 说明 - 为什么不调用赋值/复制构造函数
- 防止在复制构造函数中隐式调用基构造函数
- 为用户定义的类正确调用复制构造函数/赋值运算符
- 具有已删除移动和复制构造函数的类的就地构造
- 复制构造函数隐式转换问题
- 复制构造函数中的递归调用