无法在不键入别名类型

时间:2017-09-21 17:20:02

标签: c++ c++11 templates c++14 generic-programming

我有类似别名 X Sample.hpp 等类模板。

#ifndef SAMPLE_HPP
#define SAMPLE_HPP

template<typename STA, typename STB>
class Sample
{
    using X = Sample<STA,STB>;

public:
    Sample();
    inline X* GetNext() const;

private:
    X* Next;
};

#include "Sample.cpp"

#endif // SAMPLE_HPP

定义在 Sample.cpp 中。

#include "Sample.hpp"

template<typename STA, typename STB>
Sample<STA,STB>::Sample() {
    Next = nullptr;
}

template<typename STA, typename STB>
typename Sample<STA,STB>::X* Sample<STA,STB>::GetNext() const {
    return this->Next;
}

我的问题是,还有其他方法可以定义 GetNext 功能。例如,没有 typename 或没有示例类模板的完整声明。当我将代码更改为

template<typename STA, typename STB>
Sample<STA,STB>* Sample<STA,STB>::GetNext() const {
    return this->Next;
}

它可以工作,但我不能直接在这里使用类型别名,例如:

template<typename STA, typename STB>
X* Sample<STA,STB>::GetNext() const {
    return this->Next;
}

1 个答案:

答案 0 :(得分:4)

您可以在auto的帮助下使用尾随返回类型:

template<typename STA, typename STB>
auto Sample<STA, STB>::GetNext() const -> X* {
    return this->Next;
}