【发布时间】:2014-06-20 09:56:27
【问题描述】:
我有以下代码:
#include <type_traits>
struct TType
{
int a = 0;
bool operator() (int&)
{
return true;
}
};
int main()
{
static_assert(std::is_same<decltype(std::declval<TType>()(std::declval<int>())), bool>::value, "wtf?");
return 0;
}
如果我尝试使用 g++-4.8.2 编译它,则会收到错误消息:
main.cpp:321:82: error: no match for call to ‘(JetPlane) (int)’
static_assert(std::is_same<decltype(std::declval<JetPlane>()(std::declval<int>())), bool>::value, "wtf?");
^
main.cpp:265:8: note: candidate is:
struct JetPlane
^
main.cpp:279:7: note: bool JetPlane::operator()(int&)
bool operator() (int&)
^
main.cpp:279:7: note: no known conversion for argument 1 from ‘int’ to ‘int&’
我不明白note: no known conversion for argument 1 from ‘int’ to ‘int&’ 行。所以问题是:尽管 std::declval 声明看起来像:
template< class T >
typename std::add_rvalue_reference<T>::type declval();
我了解禁止将int&& 绑定到int。但是为什么编译器不打印:note: no known conversion for argument 1 from ‘int’ to ‘int&’ 行。可能是我不明白某些东西并且编译器以某种方式从int&& 上的int 在std::declval<TType>()(std::declval<int>()) 中的std::declval<int>() 返回类型?
感谢您的帮助!
【问题讨论】:
-
int&&无法绑定到int&。 -
是的,我明白这一点。但是为什么编译器不打印:没有已知的参数 1 从“int&&”到“int&”的转换
-
我猜这是出于遗留原因。它是
int类型的右值,并且长期以来意味着类型为int,所以这就是错误报告的内容。是的,在您的情况下,类型是int&&,但这仍然是int右值。