对付普通范例的工具来说,它们之间的复制是很简朴的,譬喻:
int a=100;
int b=a;
而类工具与普通工具差异,类工具内部布局一般较为巨大,存在各类成员变量。下面看一个类工具拷贝的简朴例子。
#include <iostream>
using namespace std;
class CA
{
public:
CA(int b)
{
a=b;
}
void Show ()
{
cout<<a<<endl;
}
private:
int a;
};
int main()
{
CA A(100);
CA B=A;
B.Show ();
return 0;
}
运行措施,屏幕输出100。从以上代码的运行功效可以看出,系统为工具B分派了内存并完成了与工具A的复制进程。就类工具而言,沟通范例的类工具是通过拷贝结构函数来完成整个复制进程的。下面我们举例说明拷贝结构函数的事情进程。
#include <iostream>
using namespace std;
class CA
{
public:
CA(int b)
{
a=b;
}
CA(const CA& C)
{
a=C.a;
}
void Show()
{
cout<<a<<endl;
}
private:
int a;
};
int main()
{
CA A(100);
CA B=A;
B.Show ();
return 0;
}
CA(const CA& C)就是我们自界说的拷贝结构函数。可见,拷贝结构函数是一种非凡的结构函数,函数的名称必需和类名称一致,它的独一的一个参数是本范例的一个引用变量,该参数是const范例,不行变的。譬喻:类X的拷贝结构函数的形式为X(X& x)。
当用一个已初始化过了的自界说类范例工具去初始化另一个新结构的工具的时候,拷贝结构函数就会被自动挪用。也就是说,当类的工具需要拷贝时,拷贝结构函数将会被挪用。以下环境城市挪用拷贝结构函数:
一个工具以值通报的方法传入函数体
一个工具以值通报的方法从函数返回
一个工具需要通过别的一个工具举办初始化。
假如在类中没有显式地声明一个拷贝结构函数,那么,编译器将会自动生成一个默认的拷贝结构函数,该结构函数完成工具之间的位拷贝。位拷贝又称浅拷贝,后头将举办说明。
自界说拷贝结构函数是一种精采的编程气势气魄,它可以阻止编译器形成默认的拷贝结构函数,提高源码效率。
浅拷贝和深拷贝
在某些状况下,类内成员变量需要动态开发堆内存,假如实行位拷贝,也就是把工具里的值完全复制给另一个工具,如A=B。这时,假如B中有一个成员变量指针已经申请了内存,那A中的谁人成员变量也指向同一块内存。这就呈现了问题:当B把内存释放了(如:析构),这时A内的指针就是野指针了,呈现运行错误。
深拷贝和浅拷贝可以简朴领略为:假如一个类拥有资源,当这个类的工具产生复制进程的时候,资源从头分派,这个进程就是深拷贝,反之,没有从头分派资源,就是浅拷贝。下面举个深拷贝的例子。
#include <iostream>
using namespace std;
class CA
{
public:
CA(int b,char* cstr)
{
a=b;
str=new char[b];
strcpy(str,cstr);
}
CA(const CA& C)
{
a=C.a;
str=new char[a]; //深拷贝
if(str!=0)
strcpy(str,C.str);
}
void Show()
{
cout<<str<<endl;
}
~CA()
{
delete str;
}
private:
int a;
char *str;
};
int main()
{
CA A(10,"Hello!");
CA B=A;
B.Show();
return 0;
}
好吧,就说这些,但愿本文能对您有所辅佐。