一、auto意义

  编程时常常需要把表达式的值赋给变量,这就要求在声明变量的时候清楚地知道表达式的类型,然后要做到这一点并非那么容易。为了解决这个问题,C++11新标准引入了auto类型说明符,用它就能让编译器替我们去分析表达式所属的类型。

二、auto用法

  1.基本用法

    int tempA = ;
int tempB = ;
/*1.正常推断auto为int,编译通过*/
auto autoTempA = tempA + tempB;
/*2.正常推断auto为int,编译通过*/
auto autoTempB = , *autoTempC = &autoTempB;
/*3.autoTempD推断为int,autoTempE推断为double,编译不过*/
auto autoTempD = , autoTempE = 3.14;

  2.与const结合

    const int ctempA = ;
auto autoTempA = ctempA; /*1.cautoTempA推断为int,但是手动加了const,所以cautoTempA最终类型为const int*/
const auto cautoTempA = ctempA;
/*2.autoTempA推断为int,忽略顶层const*/
autoTempA = ;

  3.与引用结合

    int tempA = ;
int &refTempA = tempA;
/*1.忽略引用,autoTempA推断为int,refAutoTempA被手动置为引用*/
auto autoTempA = refTempA;
auto &refAutoTempA = refTempA; autoTempA = ;
refAutoTempA = ;
/*2.输出为3,3,4,3*/
cout<<"tempA = "<<tempA<<endl;
cout<<"refTempA = "<<refTempA<<endl;
cout<<"autoTempA = "<<autoTempA<<endl;
cout<<"refAutoTempA = "<<refAutoTempA<<endl;

  4.与指针结合

   int tempA = ;
const int ctempA = ; /*1.ptrTempA中auto推断为int*,ptrTempB中推断为int */
auto ptrTempA = &tempA;
auto *ptrTempB = &tempA;
/*2.cptrTempA中auto推断为const int*,cptrTempB中推断为cosnt int */
auto cptrTempA = &ctempA;
auto *cptrTempB = &ctempA;
/*3.ptrTempA和ptrTempB输出完全一致*/
cout<<" ptrTempA = "<<ptrTempA<<endl;
cout<<"*ptrTempA = "<<*ptrTempA<<endl;
cout<<" ptrTempB = "<<ptrTempB<<endl;
cout<<"*ptrTempB = "<<*ptrTempB<<endl;
/*4.cptrTempA和cptrTempB输出完全一致*/
cout<<" cptrTempA = "<<cptrTempA<<endl;
cout<<"*cptrTempA = "<<*cptrTempA<<endl;
cout<<" cptrTempB = "<<cptrTempB<<endl;
cout<<"*cptrTempB = "<<*cptrTempB<<endl;
/*5.cptrTempA指向的为const int,不能通过cptrTempA来修改其值,编译不过*/
*cptrTempA = ;

三、auto使用总结

  上面的例子只是为了说明auto与const、引用和指针的用法,在实际工作中,auto主要还是为了简化一些复杂的声明;但是建议在使用时必须要清楚自己auto出来的类型到底是什么,这样才能做到心中有数,出现问题才能快速定位。

C++11新标准:auto关键字的更多相关文章

  1. C++11新标准:decltype关键字

    一.decltype意义 有时我们希望从表达式的类型推断出要定义的变量类型,但是不想用该表达式的值初始化变量(如果要初始化就用auto了).为了满足这一需求,C++11新标准引入了decltype类型 ...

  2. C++11新标准:nullptr关键字

    一.nullptr的意义 1.NULL在C中的定义 #define NULL (void*)0 2.NULL在C++中的定义 #ifndef NULL #ifdef __cplusplus #defi ...

  3. C++11新标准学习

    <深入理解C++11:C++11新特性解析与应用> <华章科技:深入理解C++11:C++11新特性解析与应用>一共8章:第1章从设计思维和应用范畴两个维度对C++11新标准中 ...

  4. C++11新特性— auto 和 decltype 区别和联系

    一. auto简介 编程时候常常需要把表达式的值付给变量,需要在声明变量的时候清楚的知道变量是什么类型.然而做到这一点并非那么容易(特别是模板中),有时候根本做不到.为了解决这个问题,C++11新标准 ...

  5. C++11特性:auto关键字

    前言 本文的内容已经不新鲜了.关于auto,翻来覆去被人知道的都是这些东西,本文并没有提出新颖的auto用法. 本人原是痛恨博客一篇篇都是copy而来缺乏新意的探索,当然,本文不是copy而来,但发布 ...

  6. c++11新标准for循环和lambda表达式

    :first-child { margin-top: 0px; } .markdown-preview:not([data-use-github-style]) h1, .markdown-previ ...

  7. C++11 - 类型推导auto关键字

    在C++11中,auto关键字被作为类型自动类型推导关键字 (1)基本用法 C++98:类型 变量名 = 初值;   int i = 10; C++11:auto 变量名 = 初值;  auto i ...

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

    c++11新特性--decltype decltype是C++11加入的一个新的keyword,目的是选择并返回操作数的数据类型,重要的是,在此过程中编译器分析表达式并得到它的类型,却不实际计算表达式 ...

  9. C++11新标准:constexpr关键字

    一.constexpr意义 将变量声明为constexpr类型以便由编译器来验证变量是否是一个常量表达式(不会改变,在编译过程中就能得到计算结果的表达式).是一种比const更强的约束,这样可以得到更 ...

随机推荐

  1. Brackets (区间DP)

    个人心得:今天就做了这些区间DP,这一题开始想用最长子序列那些套路的,后面发现不满足无后效性的问题,即(,)的配对 对结果有一定的影响,后面想着就用上一题的思想就慢慢的从小一步一步递增,后面想着越来越 ...

  2. UGUI技巧

    http://www.cnblogs.com/suoluo/p/5427514.html Text中的可以单独指定某些文字的颜色,只需将想要变色的文本放在<color=**></co ...

  3. flask之flask_bootstrap

    由于flask_bootstrap最近没有更新,推荐使用bootstrap_flask #~/miniconda3/envs/lesson/lib/python3.6/site-packages/fl ...

  4. [转载]Ubuntu下ssh服务的安装与登陆(ssh远程登陆)

    转载地址:http://blog.csdn.net/zht666/article/details/9340633 Ubuntu默认并没有安装ssh服务,如果通过ssh远程连接到Ubuntu,需要自己手 ...

  5. Linux驱动多线程 - 互斥量

    1.内核多线程相关内容 1.1 头文件#include <linux/kthread.h> 1.2 定义/初始化变量 struct mutex SPI_work; /*定义互斥体*/ mu ...

  6. 使用 acl 库针对 C++ 对象进行序列化及反序列编程

    在开发网络应用程序时,各个模块之间的数据通信可谓是家常便饭,为了应对这些数据通信时数据交换的要求,程序员发明了各种数据格式:采用二进制数据结构(早期 C 程序员).采用 XML.采用SOAP(坑人的设 ...

  7. Python:序列的copy() 方法和 copy 模块

    转于:Python中copy和deepcopy中的区别 博主:assan 一.序列中的 copy() 方法 # 此方法为浅度复制:复制的数会随着被复制数的嵌套序列的元素的改变而改变: # 功能:将一个 ...

  8. Thread之四:java线程返回结果的方法

    两种方式:一种继承Thread类实现:一种通过实现Callable接口. 第一种方法: 因为实现Thread类的run方法自身是没有返回值的,所以不能直接获得线程的执行结果,但是可以通过在run方法里 ...

  9. 使用Spring AMQP开发消费者应用

    前一篇中我们介绍了使用RabbitMQ Java Client访问RabbitMQ的方法.但是使用这种方式访问RabbitMQ,开发者在程序中需要自己管理Connection,Channel对象,Co ...

  10. C# IL中间代码注入实现切面编程

    背景及现状:之前分享的那篇“面向切面编程–渲染监控日志记录方案”中提供了利用RealProxy作为代理类来生成代理的面向切面的编程方法,那个方法可以实现面向切面编程进行日志记录,现在渲染主程序也是采用 ...