Oma*_*mar 5 c++ oop copy-constructor
复制构造函数用于许多事情,例如当我需要使用指针或为对象动态分配内存时.但是看看这个例子tutorialpoint.com:
#include <iostream>
using namespace std;
class Line
{
public:
int getLength( void );
Line( int len ); // simple constructor
Line( const Line &obj); // copy constructor
~Line(); // destructor
private:
int *ptr;
};
// Member functions definitions including constructor
Line::Line(int len)
{
cout << "Normal constructor allocating ptr" << endl;
// allocate memory for the pointer;
ptr = new int;
*ptr = len;
}
Line::Line(const Line &obj)
{
cout << "Copy constructor allocating ptr." << endl;
ptr = new int;
*ptr = *obj.ptr; // copy the value
}
Line::~Line(void)
{
cout << "Freeing memory!" << endl;
delete ptr;
}
int Line::getLength( void )
{
return *ptr;
}
void display(Line obj)
{
cout << "Length of line : " << obj.getLength() <<endl;
}
// Main function for the program
int main( )
{
Line line(10);
display(line);
return 0;
}
Run Code Online (Sandbox Code Playgroud)
结果是:
Normal constructor allocating ptr
Copy constructor allocating ptr.
Length of line : 10
Freeing memory!
Freeing memory!
Run Code Online (Sandbox Code Playgroud)
当我注释掉(复制构造函数)和析构函数内的代码时,我得到了相同的结果:
Normal constructor allocating ptr
Length of line : 10
Run Code Online (Sandbox Code Playgroud)
那么在这里使用复制构造函数有什么区别呢?也为什么"释放记忆!" 发生两次?
函数的参数display()是按值传递的,因此编译器调用复制构造函数来创建它。当类定义其复制构造函数时,您将获得正确的语义:复制构造函数创建一个副本,并且该副本有自己的内存来保存长度。当您删除复制构造函数时,编译器会为您生成一个复制构造函数,并且传递给的副本display()具有与原始指针相同的指针。当该副本被销毁时,它会删除 ptr 指向的内存。当原始内存被破坏时,它会再次删除相同的内存(这里碰巧没有可见的影响)。这绝对不是您想要发生的情况,这就是为什么您需要定义一个复制构造函数。正如@Joe所说:在析构函数内,打印“ptr”的值以更清楚地看到这一点。