C++11之auto和decltype

  • auto自动类型推断,用于从初始表达式中推断出变量的类型。
  1. auto a; // 错误,没有初始化表达式,无法推断出a的类型
  2. auto int a = 10; // 错误,auto临时变量的语义在C++ 11中已不存在
  3. auto a = 10;
  4. auto c = ‘A‘;
  5. auto s("hello");
  6. vector<int> vctTemp;
  7. auto it = vctTemp.begin();
  8. auto ptr = [](){ cout << "hello world" << endl; };
  • auto返回值占位,主要与decltype配合使用,用于返回值类型后置时的占位。
  1. template <class T, class U>
  2. auto Multiply(T t, U u)->decltype(t*u)
  3. {
  4. typedef decltype(t*u) NewType;
  5. NewType *pResult = new NewType(t*u);
  6. return *pResult;
  7. }

decltype相关用法说明

类似于sizeof操作符,decltype也不需对其操作数求值(而auto会执行表达式)。粗略来说,decltype(e)返回类型前,进行了如下推导:

  1. 若表达式e指向一个局部变量、命名空间作用域变量、静态成员变量或函数参数,那么返回类型即为该变量(或参数)的“声明类型”;
  2. 若e是一个左值(lvalue,即“可寻址值”),则decltype(e)将返回T&,其中T为e的类型;
  3. 若e是一个x值(xvalue),则返回值为T&&;
  4. 若e是一个纯右值(prvalue),则返回值为T。

1、表达式根据其值的类型可分为以下三类:

  • lvalue:左值,即传统意义上的左值。
  • xvalue(expiring value):x值(中间值?),指通过“右值引用”产生的对象。
                                     这里x可以理解为即将消失(expiring),也可理解为中间(横跨左值和右值)。
  • prvalue(pure rvalue):纯右值,即传统意义上的右值。

2、两种复合类型:

  • glvalue(general lvalue):泛左值,由左值和x值构成。泛左值具有动态的类型和对象属性。
  • rvalue:右值,由x值和纯右值构成。右值具有潜在的可移动性。

3、关于右值引用:

  • 具名右值引用被视为左值。
  • 无名右值引用被视为x值。
  • 对函数的右值引用无论具名与否都将被视为左值。
  1. decltype(fun()) sum = x;//sum的类型就是函数fun的返回值类型
  2. const int ci = 0, &cj = ci;
  3. decltype(ci) x = 0; //x的类型是const int型
  4. decltype(cj) y = x; //y的类型是const int&,y绑定到变量x
  5. decltype(cj) z;//错误,引用类型必须被初始化
  6. int i = 42, *p = &i, &r = i;
  7. decltype(r + 0) b; //r+0的结果是int型
  8. //通过解引用可以给指针指向的对象赋值,说明解引用操作返回的是引用类型的
  9. decltype(*p) c;//错误,c是int&,必须被初始化
  10. //decltype结果类型与表达式形式密切相关
  11. decltype((i)) d;//错误,d是int&类型,必须初始化
  12. decltype(i) e;//正确,e是一个int类型

来自为知笔记(Wiz)

时间: 2024-10-20 13:53:32

C++11之auto和decltype的相关文章

C++11的auto和decltype关键字

今天Mayuyu要介绍C++11中两个重要的关键字,即auto和decltype.实际上在C++98中,已经就有了auto关键字,只不过在C++98中auto表示的是临时变量的语义,而在C++11中auto表示自动类型推导,如下 auto关键字可以从表达式中推导出变量的类型,这样就大大简化了编程人员的工作.而且auto是在编译时对变量进行了类型推导,所以不会对程序的效率造成影响,另外auto也不会对编译速度造成太大影响,因为编译时本身也要右侧推导后判断是否与左侧匹配. 另外auto在模板编程中也

c++11 auto 与 decltype 详解

转自: here 一. auto简介 编程时候常常需要把表达式的值付给变量,需要在声明变量的时候清楚的知道变量是什么类型.然而做到这一点并非那么容易(特别是模板中),有时候根本做不到.为了解决这个问题,C++11新标准就引入了auto类型说明符,用它就能让编译器替我们去分析表达式所属的类型.和原来那些只对应某种特定的类型说明符(例如 int)不同.auto 让编译器通过初始值来进行类型推演.从而获得定义变量的类型,所以说 auto 定义的变量必须有初始值. [cpp] view plain co

C++ 11 学习1:类型自动推导 auto和decltype

Cocos 3.x 用了大量的C++ 11 的东西,所以作为一个C++忠实粉丝,有必要对C++ 11进行一个系统的学习. 使用C++11之前,一定要注意自己使用的编译器对C++11的支持情况,有些编译器并不是完全支持,比如我正在使用的vs2012.这里是msdn里面VS各版本对C++ 11 的支持 对 C++11 功能的支持(现代 C++) 1.auto auto这个关键字C++原先就有,用来指定存储器.因为很少有人去用这个东西,所以在C++11中就把原有的auto功能给废弃掉了,而变成了现在的

c++11 auto 和 decltype

一. auto简介编程时候常常需要把表达式的值付给变量,需要在声明变量的时候清楚的知道变量是什么类型.然而做到这一点并非那么容易(特别是模板中),有时候根本做不到.为了解决这个问题,C++11新标准就引入了auto类型说明符,用它就能让编译器替我们去分析表达式所属的类型.和原来那些只对应某种特定的类型说明符(例如 int)不同.auto 让编译器通过初始值来进行类型推演.从而获得定义变量的类型,所以说 auto 定义的变量必须有初始值. 1 //由val_1 和val_2相加的结果可以推断出it

关于auto和decltype

1 auto会忽略顶层const,保留底层const 2 3 int i = 0; 4 5 const int* const p = &i; 6 7 auto p2 = p; //p2是const int*,不是const int* const 8 //*p2 = 4; //错误,p指向常量 9 p2 = nullptr; //正确,p2本身不是常量 10 11 12 auto不会保留引用类型,应该使用auto& 13 14 int& x = i; 15 16 auto m = x

C++11 新特性之 decltype关键字

decltype关键字用于查询表达式的类型.与其他特性结合起来之后会有意想不到的效果. decltype的语法是 decltype (expression) 实例: #include <iostream> #include <typeinfo> using namespace std; int main() { int i; double d; float f; struct A { int i; double d; }; decltype(i) i1; cout <<

C++之auto与decltype

C++11中新增了两种推倒型别的方法,auto和decltype,从而我们的变量定义就方便了很多. 一.auto关键词是根据其初始化物的类型来推导的. (1)推倒时忽略初始化物本身的const属性.如: int x=0; auto a=x,b=0; cout<<typeid(a).name()<<"\t"<<typeid(b).name()<<endl; 输出: i  i(i代表int类型) (2)若为指针或引用,保留其应指涉物的cons

关注C++细节——C++11新标准之decltype的使用注意

c++11新特性--decltype decltype是C++11添加的一个新的关键字,目的是选择并返回操作数的数据类型,重要的是,在此过程中编译器分析表达式并得到它的类型,却不实际计算表达式的值. 对于内置类型的对象,使用decltype很直观,但当参数为复合类型的时候就应该注意一些使用细节问题. 1.当decltype作用于数组的时候就应该小心了,本文作者(CSDN   iaccepted). intiarr[10] = {0}; decltype(iarr)ib; 这个时候ib的定义等价于

代码简洁之道:C++ 11 之auto+ for_each + lamda表达式

摘要:在很多中情况下,我们需要这样的运算:给vector中每个元素进行相似的处理(每个元素+1,或者其他).一般情况下,我们会选用for循环,然后然后对每个元素进行处理.实际上,C++ 11提供了了lamda表达式,结合for_each,可以写出更加简洁和高效的代码. 1.for_each.简介 for_each是C++中的模板,具体用法可以参考这里:http://www.cplusplus.com/reference/algorithm/for_each/ 2.lamda表达式 lamda表达