随着GCC 4.8.0的发布,我们有了一个支持自动返回类型推导的编译器,它是C ++ 14的一部分。使用-std=c++1y
,我可以这样做:
auto foo() { //deduced to be int
return 5;
}
我的问题是:什么时候应该使用此功能?什么时候需要,什么时候可以使代码更简洁?
场景1
我能想到的第一种情况是尽可能的。可以用这种方式编写的每个函数都应该如此。这样做的问题是,它可能并不总是使代码更具可读性。
方案2
下一种情况是避免使用更复杂的返回类型。作为一个非常简单的示例:
template<typename T, typename U>
auto add(T t, U u) { //almost deduced as decltype(t + u): decltype(auto) would
return t + u;
}
尽管在某些情况下让返回类型显式依赖于参数,但我认为这绝对不会成为问题。
场景3
接下来,为了防止冗余:
auto foo() {
std::vector<std::map<std::pair<int, double>, int>> ret;
//fill ret in with stuff
return ret;
}
在C ++ 11中,有时我们可以return {5, 6, 7};
代替向量,但这并不总是可行的,我们需要在函数头和函数体中指定类型。这纯粹是多余的,自动返回类型推导使我们免于这种冗余。
方案4
最后,它可以代替非常简单的功能:
auto position() {
return pos_;
}
auto area() {
return length_ * width_;
}
但是有时候,我们可能要看一下函数,想知道确切的类型,如果那里没有提供它,我们就必须转到代码的另一点,例如pos_
声明的位置。
结论
在布置了这些方案之后,实际上哪个方案证明可以使用此功能来使代码更简洁?我在这里忽略提及的情况又如何呢?使用此功能之前应采取哪些预防措施,以免以后被我咬到?没有此功能,表格是否有新功能?
请注意,多个问题旨在帮助您找到可以回答这个问题的观点。
->decltype(t+u)
用自动扣除替代会杀死SFINAE。