关于C++复制构造函数的一些纳闷

关于C++复制构造函数的一些困惑
书上介绍是时说了一种复制构造函数应用的方面,其中有一个是:
函数的返回值是类的对象,函数返回时调用复制构造函数,但是我的程序
#include <iostream>
using namespace std;
class Point
{
private:
    int x,y;
public:
    Point(int xx=0,int yy=0){
        x=xx;
        y=yy;
    }
    Point(Point &p);
    int getX(){
        return x;
    }
    int getY(){
        return y;
    }
};

Point::Point(Point &p){
    x=p.x;
    y=p.y;
    cout<<"Calling the copy constructor"<<endl;
}

Point fun2(){
    Point a(1,2);
    return a;
}

int main()
{
    Point b;
    b=fun2();           //情况3,函数的返回值是类对象,怎么没有显示Calling the copy constructor
    return 0;           //没调用复制构造函数吗?
}

------解决方案--------------------

这个不会调用复制构造函数,而是会调用复制函数。

重载这个你就知道了。



class Point
{
  // ..... your other code.....
  const Point& operator=( const Point& pt )
  {
       if( this != &pt )
       {
           x = pt.x;
           y = pt.y;
           cout<< " haha, It's here!!";
       }
   }

------解决方案--------------------
楼上的别瞎说..明显调用了拷贝构造函数,a返回时会生成一个临时对象(这里就是拷贝),然后再调用=重载,把临时对象赋给b
一般编译器都有返回值优化选项,不知道楼主是什么编译器,有没有开优化。
我这里没问题,显示的是:
//Calling the copy constructor
// haha, It's here!!
吐槽下,楼上的,写代码写写全好么,return都没有...
------解决方案--------------------
RVO
------解决方案--------------------
NRVO
------解决方案--------------------
好吧,完善一下我的代码。至于到底是神马情况,楼主测试吧。

class Point
{
  // ..... your other code.....
  const Point& operator=( const Point& pt )
  {
       if( this != &pt )
       {
           x = pt.x;
           y = pt.y;
           cout<< " haha, It's here!!";
       }
       return *this;
   }
};

------解决方案--------------------
。。一楼说的什么乱七八糟的  咱不会可以 但是不能误人子弟 关于C++复制构造函数的一些纳闷
------解决方案--------------------
编译器优化了,理论上是在函数返回值的时候调用复制构造函数构造一个临时量,再调用赋值构造函数进行赋值,编译器优化了临时量那步奏了,直接调用了赋值构造函数。
------解决方案--------------------
计算机组成原理→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对应的汇编并单步执行观察相应内存和寄存器变化。)

------解决方案--------------------
返回值优化。。。
建议google下
------解决方案--------------------
sdhexu 正解。
不过可怜的sdhexu