c ++中的子类型多态性

我用c ++编写了这个程序。 ref2.h:
#ifndef REF2_H
#define REF2_H
#include <iostream>
using std::cout;
using std::endl;

int   add_int_int(int a, int b) {return (a+b);}

class IntClass;

class Number {
    public:

        //return a Number object that's the results of x+this, when x is IntClass
        virtual Number& addInt(IntClass& x) = 0;

        //Print the number stored in the object
        virtual void print_number() = 0;
    }

class IntClass : public Number {

    private:
        int my_number;

    public:
        //Constructor
        IntClass(int n):my_number(n) {}

        //returns the number stored in the object
        int get_number()  {return my_number;}

        //print the number stored in the object
        void print_number() {cout << my_number << endl;}

        Number& addInt(IntClass& x);
    }

Number& IntClass::addInt(IntClass& x)
{
    int n = add_int_int(my_number, x.get_number());
    IntClass elem = IntClass(n);
    IntClass &ref = elem;
    return ref;     
}

#endif
TEST.CPP
#include "ref2.h"
#include <iostream>
using std::cout;
using std::endl;


int main() {    
    cout << "Testing subtyping polymorphism:" << endl;
    IntClass ia(1);
    IntClass ib(2);
    Number& num = ia.addInt(ib);     num.print_number();  //should be: 3
}
我没有发现我的错误。 如果有人可以帮助我吗?     
已邀请:
您将在addInt()中返回对局部变量的引用。不要那样做。编译器应该警告你。     
addInt()
返回时,您将返回对超出范围的本地对象的引用:
IntClass elem = IntClass(n);
IntClass &ref = elem;
return ref;    
    
返回对数字的引用的概念(在这种情况下)是有缺陷的。想象一个像指针一样的引用。函数IntClass :: addInt在堆栈上分配一个新的IntClass对象,然后返回对它的引用。 当函数返回时,IntClass的内存被释放,因此引用指向garbage。 你应该返回一个指向Number(Number *)的指针,你需要使用
new IntClass
来创建一个。然后,当你使用完它后,你还需要打电话给
delete
。     

要回复问题请先登录注册