关于构造函数拷贝构造函数的有关问题
关于构造函数拷贝构造函数的问题
我写了如下的测试用例,希望从f()函数中返回的值在main()函数中使用,但编译总是报错如下:
g++ t1.cpp
t1.cpp: In function ‘int main()’:
t1.cpp:21: error: no matching function for call to ‘A::A(A)’
t1.cpp:9: note: candidates are: A::A(A&)
t1.cpp:8: note: A::A(int)
t1.cpp:7: note: A::A()
源程序如下:
#include <iostream>
#include <cstdio>
using namespace std;
class A{
public:
A(){cout<<"con1"<<endl;};
A(int){cout<<"con"<<endl;};
A(A& a){cout<<"copy"<<endl;};
~A(){cout<<"d"<<endl;};
int i;
};
A f()
{
A i(1);
return i;
}
int main()
{
A i = f();
printf("====&i=%x\n",&i);
}
请教诸位达人,这是什么原因?
------解决方案--------------------
------解决方案--------------------
楼上需要温柔点
------解决方案--------------------
你看一下结果,从fun函数中得到返回值赋值给main函数中的b,其实调用了拷贝构造函数
------解决方案--------------------
计算机组成原理→DOS命令→汇编语言→C语言(不包括C++)、代码书写规范→数据结构、编译原理、操作系统→计算机网络、数据库原理、正则表达式→其它语言(包括C++)、架构……
对学习编程者的忠告:
眼过千遍不如手过一遍!
书看千行不如手敲一行!
手敲千行不如单步一行!
单步源代码千行不如单步对应汇编一行!
单步类的实例“构造”或“复制”或“作为函数参数”或“作为函数返回值返回”或“参加各种运算”或“退出作用域”的语句对应的汇编代码几步后,就会来到该类的“构造函数”或“复制构造函数”或“运算符重载”或“析构函数”对应的C/C++源代码处。
VC调试时按Alt+8、Alt+7、Alt+6和Alt+5,打开汇编窗口、堆栈窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应堆栈、内存和寄存器变化,这样过一遍不就啥都明白了吗。
对VC来说,所谓‘调试时’就是编译连接通过以后,按F10或F11键单步执行一步以后的时候,或者在某行按F9设了断点后按F5执行停在该断点处的时候。
(Turbo C或Borland C用Turbo Debugger调试,Linux或Unix下用GDB调试时,看每句C对应的汇编并单步执行观察相应内存和寄存器变化。)
不要迷信书、考题、老师、回帖;
要迷信CPU、编译器、调试器、运行结果。
并请结合“盲人摸太阳”和“驾船出海时一定只带一个指南针。”加以理解。
任何理论、权威、传说、真理、标准、解释、想象、知识……都比不上摆在眼前的事实!
有人说一套做一套,你相信他说的还是相信他做的?
其实严格来说这个世界上古往今来所有人都是说一套做一套,不是吗?
不要写连自己也预测不了结果的代码!
我写了如下的测试用例,希望从f()函数中返回的值在main()函数中使用,但编译总是报错如下:
g++ t1.cpp
t1.cpp: In function ‘int main()’:
t1.cpp:21: error: no matching function for call to ‘A::A(A)’
t1.cpp:9: note: candidates are: A::A(A&)
t1.cpp:8: note: A::A(int)
t1.cpp:7: note: A::A()
源程序如下:
#include <iostream>
#include <cstdio>
using namespace std;
class A{
public:
A(){cout<<"con1"<<endl;};
A(int){cout<<"con"<<endl;};
A(A& a){cout<<"copy"<<endl;};
~A(){cout<<"d"<<endl;};
int i;
};
A f()
{
A i(1);
return i;
}
int main()
{
A i = f();
printf("====&i=%x\n",&i);
}
请教诸位达人,这是什么原因?
------解决方案--------------------
A(int){cout<<"con"<<endl;}; //形参名都没有,这怎么在函数体内部用形参
A(A& a){cout<<"copy"<<endl;}; //光输出一句话,成员变量的值复制都没有,这写了干嘛
------解决方案--------------------
楼上需要温柔点
------解决方案--------------------
你看一下结果,从fun函数中得到返回值赋值给main函数中的b,其实调用了拷贝构造函数
------解决方案--------------------
计算机组成原理→DOS命令→汇编语言→C语言(不包括C++)、代码书写规范→数据结构、编译原理、操作系统→计算机网络、数据库原理、正则表达式→其它语言(包括C++)、架构……
对学习编程者的忠告:
眼过千遍不如手过一遍!
书看千行不如手敲一行!
手敲千行不如单步一行!
单步源代码千行不如单步对应汇编一行!
单步类的实例“构造”或“复制”或“作为函数参数”或“作为函数返回值返回”或“参加各种运算”或“退出作用域”的语句对应的汇编代码几步后,就会来到该类的“构造函数”或“复制构造函数”或“运算符重载”或“析构函数”对应的C/C++源代码处。
VC调试时按Alt+8、Alt+7、Alt+6和Alt+5,打开汇编窗口、堆栈窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应堆栈、内存和寄存器变化,这样过一遍不就啥都明白了吗。
对VC来说,所谓‘调试时’就是编译连接通过以后,按F10或F11键单步执行一步以后的时候,或者在某行按F9设了断点后按F5执行停在该断点处的时候。
(Turbo C或Borland C用Turbo Debugger调试,Linux或Unix下用GDB调试时,看每句C对应的汇编并单步执行观察相应内存和寄存器变化。)
不要迷信书、考题、老师、回帖;
要迷信CPU、编译器、调试器、运行结果。
并请结合“盲人摸太阳”和“驾船出海时一定只带一个指南针。”加以理解。
任何理论、权威、传说、真理、标准、解释、想象、知识……都比不上摆在眼前的事实!
有人说一套做一套,你相信他说的还是相信他做的?
其实严格来说这个世界上古往今来所有人都是说一套做一套,不是吗?
不要写连自己也预测不了结果的代码!