时间:2021-05-20
C++11新标准增加的auto不仅可以自动推断变量类型,还能结合decltype来表示函数的返回值。这些新特性可以让我们写出更简洁、更现代的代码。
在泛型编程中,可能需要通过参数的运算来得到返回值的类型。
我们看一下下面这个例子:
#include<iostream>using namespace std;template <typename R,typename T, typename U>R add(T t,U u){ return t+u;}int main(){ int a=1; float b=2.0; auto c = add<decltype(a+b)>(a,b);}我们并不关心a+b类型是什么,因为,只需要通过decltype(a+b)直接得到返回值类型即可。但像上面这样使用十分不方便,因为外部其实并不知道参数之间应该如何运算,只有add函数才知道返回值应当如何推导。
那么我们可不可以直接在函数定义上通过decltype拿到返回值呢?比如像这样:
template <typename T, typename U>decltype(t+u) add(T t,U u) //编译错误,t,u未定义{ return t+u;}运行后,编译器会提示错误,告诉我们decltype(t+u)中t和u在此作用域中尚未声明。
因为t、u在参数列表中,而C++的返回值是前置语法,在返回值定义的时候参数变量还不存在。
对于本例子,可行的写法如下:
template <typename T, typename U>decltype(T()+U()) add(T t,U u) { return t+u;}考虑到T、U可能是没有无参构造函数的类,正确的写法应该是这样:
template <typename T, typename U>decltype((*(T*)0)+(*(U*)0)) add(T t,U u) { return t+u;}虽然成功地使用decltype完成了返回值的推导,但写法过于晦涩,会大大增加decltype在返回值类型推导上的使用难度并降低了代码的可读性。
因此,在C++11中增加了返回类型后置语法,将decltype和auto结合起来完成返回值类型的推导。
返回类型后置语法是通过auto和decltype结合起来使用的。上面的add函数,使用新的语法可以写成:
template <typename T, typename U>auto add(T t,U u) ->decltype(t+u) { return t+u;}为了进一步说明这个语法,再看另一个例子:
#include<iostream>using namespace std;int& foo(int& i);float foo(float& f);template <typename T>auto func(T& val) -> decltype(foo(val)){ return foo(val);}在这个例子中,使用decltype结合返回值后置语法很容易推导出了foo(val)可能出现的返回值类型,并将其用到了func上。
返回值类型后置语法,是为了解决函数返回值类型依赖于参数而导致难以确定返回值类型的问题。有了这种语法以后,对返回值类型的推导就可以用清晰的方式描述出来。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
前面程序喵介绍过C++11的新特性,在这里(),这篇文章介绍下C++14的新特性。函数返回值类型推导C++14对函数返回类型推导规则做了优化,先看一段代码:#i
前言本文主要给大家介绍了C++11统一初始化语法的相关内容,关于在当前新标准C++11的语法看来,变量合法的初始化器有如下形式:Xa1{v};Xa2={v};X
__alignof运算符C++11引入alignof运算符,该运算符返回指定类型的对齐方式(以字节为单位)。为实现最大的可移植性,应使用alignof运算符,而
c++11之后有了标准的线程库:std::thread。之前一些编译器使用C++11的编译参数是-std=c++11g++-std=c++11test.cpps
本节讨论下在C++11中怎样使用std::async来执行异步task。C++11中引入了std::async什么是std::asyncstd::async()