BackPort C 14返回类型扣除对C 11
Backport C++14 return type deduction to C++11
如何使此代码c 11符合?
template <class ...Args>
auto operator()(Args&&... args) const
{
return _delegate(std::forward<Args>(args)...);
}
代码是模板结构的一部分。_delegate是一个成员,如下所示。
/// The implementation of the slot, as a delegate.
typedef fastdelegate::FastDelegate<Signature> impl_delegate;
impl_delegate _delegate;
可以在此处找到完整的文件。它是slot.hpp。https://github.com/miguelmartin75/wink-signals/tree/master/master/wink
您可以简单地添加 taild返回类型:
template <class ...Args>
auto operator()(Args&&... args) const
-> decltype(_delegate(std::forward<Args>(args)...))
{
return _delegate(std::forward<Args>(args)...);
}
live wandbox示例
如果您的编译器在 taxting返回类型中抱怨_delegate
,请尝试使用std::declval</* type of '_delegate' */>()
。
请注意,上面的代码可能与C 14的行为不同。考虑与以下成员函数超载的情况:
auto operator()(...) const { }
在C 14中,自动返回类型的扣除不是对SFINAE友好友好,因此问题中的原始功能可能会导致_delegate(std::forward<Args>(args)...)
不正确而不是Sfinae-ing,可能会导致硬编译错误。
在C 11中,_delegate(std::forward<Args>(args)...)
是签名的一部分 - 如果它不正确,其他过载也将有机会选择。
这是Wandbox上的实时示例。不注重线15
查看更改。
相关文章:
- 如何获取std::result_of函数的返回类型
- 奇怪的结构&GCC&clang(void*返回类型)
- 如何建立使用模板函数的lambda函数的尾部返回类型
- 为什么与常规GCC不同,即使有"学究性错误",MinGW-GCC也能容忍丢失的返回类型
- 在没有定义返回类型的函数中返回布尔值,并将结果保存在无错误的char编译中-为什么
- 特征::矩阵<双精度,1,3> 结构类型函数中的返回类型函数
- 函数作为模板参数,是否对返回类型强制约束
- C++中函数的向量返回类型引发错误
- 检查函数返回类型是否与STL容器类型值相同
- 为什么返回类型中需要typename?C++
- <Windows>为什么 std::thread::native_handle 返回类型为"long long unsigned int"的值,而不是 void*(又名 HANDLE)?
- 警告:在函数返回类型 [-Wignore 限定符] 时忽略类型限定符
- 为什么 c++(g++) 不允许模板返回类型和函数名称之间有空格?
- 为什么返回类型的'const'限定符对标有 __forceinline/内联的函数没有影响?
- 推导 std::vector::back() 的返回类型
- 在 c++ 中将函数返回类型指定为模板参数
- 使用 SWIG 更改生成的 CS 函数中的返回类型
- QtQuick - qml:28:错误:未知方法返回类型:自定义类型
- 基于返回类型的转换和过载扣除
- BackPort C 14返回类型扣除对C 11