Проблема доступа к внутреннему классу наследования шаблонов - PullRequest
9 голосов
/ 16 мая 2011

Не могу поверить, gcc не примет следующий код ... Пожалуйста, скажите мне, если доступ к внутреннему классу из базового шаблона действительно невозможен, или я что-то упустил?

template <class T> class BaseClass
{
public:
    struct MyStruct
    {
        T *data;
    };
};

template <class T> class ChildClass : public BaseClass <T>
{
    public:

    void problem()
    {
        MyStruct ms1; //error: 'MyStruct' was not declared in this scope
        ::MyStruct ms2; //error: '::MyStruct' has not been declared
        BaseClass<T>::MyStruct ms3; //error: expected `;' before 'ms3'
    }
};

Ответы [ 2 ]

15 голосов
/ 16 мая 2011

Проблема в том, что MyStruct является зависимым именем, поэтому вы должны указать компилятору отложить поиск имени до создания экземпляра шаблона, указав в нем имя базового класса:

typename BaseClass<T>::MyStruct ms1;

ДляДля получения дополнительной информации я прочитал бы статью часто задаваемых вопросов Parashift C ++, "Почему я получаю ошибки, когда мой производный от шаблона класс использует вложенный тип, который он наследует от своего базового класса шаблона?"

6 голосов
/ 16 мая 2011
BaseClass<T>::MyStruct ms3;

Должно быть

typename BaseClass<T>::MyStruct ms3;

Поскольку MyStruct является зависимым именем, то есть оно зависит от аргумента шаблона.
Соответствует: Где и почемупоставить «template» и «typename» на зависимые имена?

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...