在这个概念定义中:
#include <utility>
template<class Func, class Ret, class... Args>
concept Invokable = requires(Func f) {
{ f(std::declval<Args>()...) } -> Ret;
};
当像这样实例化时:
static_assert(Invokable<decltype([](int){}), void, int>);
gcc-9.0.1(主干)产生了转储(确切地说是标准库的实现):
$ g++ -O2 -std=c++2a -fconcepts -Wall -Wextra -Werror -c tu1.cpp error: static assertion failed: declval() must not be used! 2204 | static_assert(__declval_protector<_Tp>::__stop, | ^~~~~~
演示:https://godbolt.org/z/D0ygU4
拒绝此代码是否正确?如果不是,我做错了什么?如果是,则应该在哪里报告此错误?
备注
这是被接受的
template<auto f, class... Args>
constexpr auto size_of_return_type = sizeof(f(std::declval<Args>()...));
当这样实例化时:
static_assert(sizeof(int) == size_of_return_type<[](int){ return 0; }, int>);
演示: https://godbolt.org/z/gYGk8U
C++2a最新的草案说明:
[expr.prim.req]/2
需要表达式是一个布尔类型的prvalue,其值如下所述。出现在要求体内的表达式是未评估的操作数。
std::forward
的评论。 - YSC