在派生类中使用基类typedef

时间:2017-12-17 10:33:17

标签: c++

我尝试在派生类中使用基类typedef作为返回类型。

template <typename T>
class Base{
public:
    typedef size_t size_type;
    virtual size_type size() = 0;
};

template <typename T>
class Derived : public Base<T> {
public:
    using typename Base<T>::size_type;
    virtual size_type size();
};

template <typename T>
typename Derived<T>::size_type Derived<T>::size() {
    return 1;
}

clang可以编译代码,而msvc则不能。编译器说“大小的定义与其声明不符”。

我修改了代码:

template <typename T>
typename Base<T>::size_type Derived<T>::size() {
    return 1;
}

情况正好相反。

我认为typename Base<T>::size_type更有意义,因为在基类中声明的虚函数也使用基类typedef。但是clang不允许。

如果必须使用类外定义,如何修改代码以使其由两个编译器编译?

1 个答案:

答案 0 :(得分:1)

严格来说,如果Clang(和GCC,顺便说一句)接受你的代码,而MSVC没有,那通常不是你的代码有问题的迹象。长期以来,MSVC的模板实现一直不合规。

但是,认识到我们生活在现实世界中并且不得不满足于不是最优的工具,你将不得不摆脱使用声明。修改后的代码将在两个编译器上接受:

#include <cstddef>

template <typename T>
class Base{
public:
    typedef std::size_t size_type;
    virtual size_type size() = 0;
};

template <typename T>
class Derived : public Base<T> {
public:
    virtual typename Base<T>::size_type size();
};

template <typename T>
typename Base<T>::size_type Derived<T>::size() {
    return 1;
}