首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在声明后将decltype与成员函数定义一起使用

在声明后将decltype与成员函数定义一起使用
EN

Stack Overflow用户
提问于 2012-09-11 12:43:57
回答 1查看 923关注 0票数 4

我使用decltype作为成员函数的返回类型,但是定义和声明不匹配。下面是一些代码:

代码语言:javascript
复制
template<typename T>
struct A {
    T x;
    auto f() -> decltype(x);
};

template<typename T>
auto A<T>::f() -> decltype(x) {
    return this->x;
}

int main() {}

这就产生了

代码语言:javascript
复制
test.cc:10:6: error: prototype for 'decltype (((A<T>*)0)->A<T>::x) A<T>::f()' does not match any in class 'A<T>'
test.cc:6:7: error: candidate is: decltype (((A<T>*)this)->A<T>::x) A<T>::f()

不同之处在于定义具有(A<T>*)0,而声明具有(A<T>*)this。怎么回事?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-09-11 15:58:11

这是我在这里报告的gcc 4.7中的一个错误:bug #54359 (见错误报告的底部)。这个特殊的案例被gcc 4.6接受了。

作为一种解决办法,不要使用尾随返回类型,而直接使用成员x的类型。在本例中,这是简单的T,但您也可以转换更复杂的情况。例如,您可以转换:

代码语言:javascript
复制
T x;
auto f() -> decltype(x.foo);

进入:

代码语言:javascript
复制
T x;
decltype(std::declval<T>().foo) f();

std::declval在这里非常有用。

票数 8
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12362888

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档