返回类型演绎是否可能
Is return type deduction possible?
考虑一个函数,不一定模板化:
T foo(Y bar);
其中T
和Y
为类型。
我可以用decltype(bar)
得到bar
的类型。我可以写这样的代码
decltype(bar) anotherBar;
但是有一种方法可以让我获得返回类型吗?decltype(return)
在语法上是有意义的
在c++ 11中可以使用尾随返回类型,如:
auto foo(Y bar) -> decltype(some_expr(bar)) {
return some_expr(bar);
}
需要把它放在末尾,只是因为表达式依赖于作为参数声明的bar
,并且在定义返回类型的地方不存在。
c++ 14提供了(或一旦被批准)一种更简单的方法,编译器将推断函数的类型:
auto foo(Y bar) {
return some_expr(bar);
}
请注意,即使标准允许这样做,在声明中没有说明类型的事实可能会产生一些不想要的效果。对于初学者来说,如果不提供定义,就不能声明该函数(返回类型是通过查看函数体推断出来的,没有函数体,声明就没有返回类型)。此外,如果有多个返回语句,这是有问题的[我不记得确切的细节在这里]
在模板函数的情况下,只有在替换模板参数和实例化函数之后才能知道返回表达式的类型,也就是替换之后的,因此推导出的返回类型不能在SFINAE上下文中使用。
虽然c++ 14尚未批准,但一些编译器可能已经实现了此功能,请查看编译器的文档
使用函数本身的调用表达式作为decltype
的参数:
decltype(foo(bar))
您可以使用std::result_of
。
生活的例子:
#include <type_traits>
constexpr void foo();
static_assert(std::is_same<void, decltype(foo())>::value, "");
static_assert(std::is_same<decltype(foo()), std::result_of<decltype(foo)&(/*argtypes*/)>::type>::value, "nope");
int main(){}
我不知道你为什么要在模板上下文之外使用decltype
。而不是通常会提高可读性或代码的"功夫级别"。
请注意,回想起来,std::result_of
增加了代码的"功夫级别",甚至超过了仅仅使用decltype
。这并不意味着使用decltype
就可以了
相关文章:
- 在提升multi_index容器中,是否定义了"default index"?
- 在C++STL中是否有Polyval(Matlab函数)等价物?
- 检查输入是否不是整数或数字
- 是否可以初始化不可复制类型的成员变量(或基类)
- 在C++中,是否可以基于给定的标识符创建基类的新实例,反之亦然
- 是否可以通过C++扩展强制多个python进程共享同一内存
- 此代码是否违反一个定义规则
- 是否需要删除包含对象的"pair"?
- 是否可以从int转换为enum类类型
- 无论条件是否为true,if总是在c++中执行
- 如何找到大小'x'数组是否完全填充,在C++?
- 检查值是否在集合p1和p2中,但不在p3中
- 是否可以在编译时初始化数组,以便在运行时不会花费时间?
- 检查 std::shared_ptr<> 的当前底层类型是否为 T
- 在c++中检查长方体是否尽可能快地重叠(无迭代)
- 类模板专用化演绎是否应该考虑演绎指南参数初始化?
- 是否有可能通过演绎指南实现整个 std::make_tuple 功能?
- 是否可以保证模板模板参数调用用户提供的演绎指南
- 在类型演绎之后,函数模板中的替换顺序是否有任何保证
- 返回类型演绎是否可能