前情提要
在做数据结构课程设计第十题排列的时候,创建了一个Datalist的类,在Sort类中调用以保存一个随机序列。
但,每一次排序要保证不在Datalist的实例datalist上直接操作,因此每次进行不同的排列都要创建一个新的Datalist实例。
在这其中包括Sort类初始化的时候都遇见了一些情况是我没有想象到的,通过给Datalist类的构造函数和析构函数添加了Address标记,勉强能看出他们的流程。在这里记录一下。
运行结果
Address=0019FD48无参数构建
Sort::Sort()
{
instruct();
int i;
cout << "请输入要产生的随机数的个数:";
cin >> i;
datalist = Datalist(i);
datalist.showDatalist(); //debug
//……
}
我估摸着,应该是Sort类初始化在调用构造Sort()函数之前,就已经把其中的一些成员变量实例化了。否则应该先出现instruct()的指导内容,然后才是datalist的直接带参数的构建。
Address=0019FB58有参数构建
datalist = Datalist(i);
这一语句相当于创建了一个新的没有名字的Datalist实例,让datalist的值等于它(重载了operator=()的函数,否则两个Datalist变量会指向同一地址),然后Datalist析构。
Address=0019FAF4无参数构建
Datalist Sort::insertionSort(const Datalist& List)
{
Datalist list;
list = List;
//Sorting
return list;
}
//**1**
Datalist list = List
//**2**
Datalist list;
list = List;
这两种方式不一样。
第1种的list和List指向同一个对象,只调用一次构造函数。且这个构造函数既不是我们设置的已知的默认无参数构造函数,也不是我们设置的有参数的构造函数。
第2种的list先调用了一个无参数的构造函数,然后被参数List赋值。
值得注意的是return的机制,return先用不知名的构造函数构造了一个没有名字的Datalist实例,然后用不知名的复制(赋值?)函数把list的数据传给这个实例。但是在这个函数结束之前,这个实例又被析构掉了。是先析构,再RETURN。 这样可以说明为什么我在~Datalist()中delete了动态数组data后,调用函数返回一个Datalist,使用时会报错。
参考网站:
1.C++:类中的赋值函数
2.从一个例子讲解拷贝构造函数与return
纯属个人理解,有错误请批评指正。