4

当我将模板与说明符一起使用时,我收到关于不匹配的 noexcept 规范的错误noexcept。它可以使用我使用过的各种版本的 clang 进行编译,但在所有版本的 gcc 中都失败了。

struct Y
{
    void h();
};

template<typename T>
struct X
{
    void f() noexcept(noexcept(std::declval<Y>().h()));
};

template<typename T>
void X<T>::f() noexcept(noexcept(std::declval<Y>().h()))
{
}

int main()
{
}

错误:

g++ -std=c++1y -O2 -Wall -pthread main.cpp && ./a.out

main.cpp:15:56: error: declaration of 'void X<T>::f() noexcept (noexcept (declval<Y>().Y::f()))' has a different exception specifier
void X<T>::f() noexcept(noexcept(std::declval<Y>().f()))
                                                    ^
main.cpp:11:10: error: from previous declaration 'void X<T>::f() noexcept (noexcept (declval<Y>().Y::f()))'
void f() noexcept(noexcept(std::declval<Y>().f()));
     ^

这是一个错误吗?有没有办法绕过它?

4

1 回答 1

1

至少在 ideone 当前使用的 gcc-4.9.2 中,使用枚举来存储 noexcept 运算符的结果是一种可怕的解决方法。

#include <iostream>
#include <utility>

struct Y
{
    void h() noexcept;
    void i();
};

enum Y_noexcept_value
{
    h = noexcept(std::declval<Y>().h()),
    i = noexcept(std::declval<Y>().i())
};

template<typename T>
struct X
{
    void f() noexcept(Y_noexcept_value::h);
    void g() noexcept(Y_noexcept_value::i);
};

template<typename T>
void X<T>::f() noexcept(Y_noexcept_value::h)
{
}

template<typename T>
void X<T>::g() noexcept(Y_noexcept_value::i)
{
}

int main()
{
    std::cout << std::boolalpha
              << noexcept(std::declval<X<int>>().f()) << std::endl
              << noexcept(std::declval<X<int>>().g()) << std::endl;
    return 0;
}
于 2015-03-10T03:10:37.143 回答