Условная выдача оператора - PullRequest
8 голосов
/ 27 ноября 2009

У меня возникли проблемы с использованием условного оператора для получения ссылки на объект. У меня есть установка, подобная этой:

class D
{
    virtual void bla() = 0;
};

class D1 : public D
{
    void bla() {};
};

class D2 : public D
{
    void bla() {};
};

class C
{
public:
    C()
    {
        this->d1 = new D1();
        this->d2 = new D2();
    }

    D1& getD1() {return *d1;};
    D2& getD2() {return *d2;}
private:
    D1 *d1;
    D2 *d2;
};

int main()
{    
    C c;    
    D& d = (rand() %2 == 0 ? c.getD1() : c.getD2());    
    return 0;    
}

При компиляции выдается следующая ошибка:

WOpenTest.cpp: In function 'int
main()': WOpenTest.cpp:91: error: no
match for conditional 'operator?:' in
'((((unsigned int)rand()) & 1u) == 0u)
? c.C::getD1() : c.C::getD2()'

Я понимаю, что это недопустимо в соответствии со стандартом C ++ (, как видно из этого сообщения в блоге ), но я не знаю, как получить ссылку на D без использования условного оператора.

Есть идеи?

Ответы [ 3 ]

14 голосов
/ 27 ноября 2009

Приведение к D& в обеих ветвях:

D& d = (rand() %2 == 0 ? static_cast<D&>(c.getD1()) : static_cast<D&>(c.getD2()));
2 голосов
/ 27 ноября 2009

Кстати, вам не нужно использовать условный оператор,

D* dptr; if(rand() %2 == 0) dptr = &c.getD1(); else dptr = &c.getD2();
D& d = *dptr;

тоже подойдет.

0 голосов
/ 27 ноября 2009

Или вы можете изменить типы возвращаемых функций на Базовый класс.

...