полиморфизм подтипов в с ++ - PullRequest
0 голосов
/ 07 января 2011

У меня есть эта программа на 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
}

Я не нахожу свою ошибку. Если кто-нибудь может мне помочь?

Ответы [ 3 ]

4 голосов
/ 07 января 2011

Вы возвращаете ссылку на локальную переменную в addInt (). Не делай этого. Компилятор должен был предупредить вас об этом.

1 голос
/ 07 января 2011

Концепция возврата ссылки на номер (в данном случае) ошибочна. Думайте о ссылке как о указателе. Функция IntClass :: addInt выделяет новый объект IntClass в стеке, а затем возвращает ссылку на него.

Когда функция возвращается, память для IntClass освобождается, поэтому ссылка указывает на мусор.

Вы должны возвращать указатель на число (Number *), и вам нужно будет использовать new IntClass для его создания. Тогда вам также нужно будет позвонить delete, когда вы закончите его использовать.

1 голос
/ 07 января 2011

Вы возвращаете ссылку на локальный объект, который выходит из области видимости, когда addInt() возвращает:

IntClass elem = IntClass(n);
IntClass &ref = elem;
return ref;    
...