auto与decltype
今天搜狗笔试的一道选择题,原题给忘了,但记得所考的知识点。知识点很基础,但很容易忽视。
具体内容可参考C++ Primer。
auto :变量取auto后,其所对应的类型
auto一般会忽视顶层const,保留底层const。但如果将引用类型设为const,则会保留相应的顶层const。下面是C++ Primer书
中的例题,我给出了相应的标注。个人觉得比较容易犯错的地方是对常量对象取地址和对引用加auto。
int main()
{
/* int i = 0, &r = i;
auto a = r; const int ci = i, &cr = ci; auto b = ci;
auto c = cr;
auto d = &i;//指针
auto e = &ci;//对常量对象取地址是底层const
const auto f = ci; auto &g = ci;
//const &h = 42;错误,不能为非常量引用绑定字面值
const auto &j = 42; a = 42;
b = 42;
c = 42;
//d = 42;错误,应为*d=42;
//e=42; 错误,首先e为指针,其次e为底层const,不能修改其指向对象的值(*e=42)
//可以让e指向其它对象,e=d;
//g=42,错误,常量引用
*/ const int i = ;
int x = ; auto j = i;
j = ; const auto &k = i;//常量引用
//k=x;错误 auto *p = &i;//对常量对象取地址
//*p=35错误,p=&x正确 return ;
}
decltype
这个类型写代码目前还没遇到过。它的作用是返回操作数的数据类型。
处理顶层const和引用的方式与auto不完全相同。decltype返回该变量的类型,包括顶层const和引用。
const int ci = , &cj = ci;
decltype(ci) x = ;//const int
decltype(cj)y = x;//const int &
//decltype(cj) z; 错误,z是引用,必须初始化
decltype和引用:
有些表达式将向decltype返回一个引用类型--当该表达式的结果对象能作为一条赋值语句的左值
int i = , *p = &i, &r = i;
decltype(r + ) b;//decltype(r)返回的是引用,但r+0返回的是r所指类型
//decltype(*p) c; 这个很容易犯错,解引用指针是表达式,返回的是可以赋值的对象,
//因此,c的类型是int&,而非int
decltype所用的表达式,加括号和不加括号不同。如果给变量加上一层或多层括号,编译器会把它当作表达式。而变量是一种可以
作为赋值语句左值的特殊表达式,所以这样的decltype就会得到引用类型:
decltype((i))d;错误,d为引用,必须初始化
另外赋值操作也是会产生引用的一种典型表达式:
    int a = , b = ;
    decltype(a) c = a;//c=3
    decltype(a=b)d = a;//d为a的引用
auto和decltype还有一层区别是在数组上。当使用数组作为一个auto变量的初始值时,推断得到的类型为指针而非数组;
decltype不会发生上述转换。
    int ia[] = { , , , , , , , , ,  };
    auto ia2(ia);//ia2为int* 指针,指向ia的第一个元素
    //ia2=42;错误,不能用int值给指针赋值
    auto ia3(&ia[]);//这两个操作等价
    decltype(ia)ia4 = {  };
    //ia4=p;错误,不能用整型指针赋给ia4
    ia4[] = ;
另外再补充一点多维数组有关的知识:当用范围for语句访问多维数组时,除了最内层的循环,其他所有层的循环的控制变量都应该
是引用类型。
   int a[][] = {  };
    for (auto &row : a)
    {
        for (auto &col : row)
        {
            col = ;
        }
    }
编译器初始化时会自动将数组转为指针,如果不是引用,row的类型就变成了int*,内层的循环就不合法了。
auto与decltype的更多相关文章
- 关于auto和decltype
		
auto会忽略顶层const,保留底层const ; const int* const p = &i; auto p2 = p; //p2是const int*,不是const int* co ...
 - C++ 11 学习1:类型自动推导 auto和decltype
		
Cocos 3.x 用了大量的C++ 11 的东西,所以作为一个C++忠实粉丝,有必要对C++ 11进行一个系统的学习. 使用C++11之前,一定要注意自己使用的编译器对C++11的支持情况,有些编译 ...
 - c++11 auto 与 decltype 详解
		
转自: here 一. auto简介 编程时候常常需要把表达式的值付给变量,需要在声明变量的时候清楚的知道变量是什么类型.然而做到这一点并非那么容易(特别是模板中),有时候根本做不到.为了解决这个问题 ...
 - 【C++】C++11的auto和decltype关键字
		
转自: http://www.linuxidc.com/Linux/2015-02/113568.htm 今天要介绍C++11中两个重要的关键字,即auto和decltype.实际上在C++98中,已 ...
 - C++11新特性— auto 和 decltype 区别和联系
		
一. auto简介 编程时候常常需要把表达式的值付给变量,需要在声明变量的时候清楚的知道变量是什么类型.然而做到这一点并非那么容易(特别是模板中),有时候根本做不到.为了解决这个问题,C++11新标准 ...
 - [转]引用模板类中定义的类型(用typedef或using)以及auto、decltype、typename的使用
		
一.背景 使用typedef或者using定义类型别名是非常常见的手段,在c++里面,有时为了封装性,模块性等原因还会在某一个namespace或者class内部定义类型别名. 最近在写c++代码的时 ...
 - C++ 11 新特性: auto 和 decltype 区别和联系
		
一. auto简介编程时候常常需要把表达式的值付给变量,需要在声明变量的时候清楚的知道变量是什么类型.然而做到这一点并非那么容易(特别是模板中),有时候根本做不到.为了解决这个问题,C++11新标准就 ...
 - C++11 auto and decltype
		
1.auto关键字 C++新标准引入auto关键词,此auto与之前C语言的auto意义已经不一样了. 这里的auto是修饰未知变量的类型,编译器会通过此变量的初始化自动推导变量的类型. 例如:aut ...
 - auto和decltype
		
auto 1.编译器通过分析表达式的类型来确定变量的类型,所以auto定义的变量必须有初始值. auto i=; //ok,i为整型 auto j; //error,定义时必须初始化. j=; ...
 
随机推荐
- C#--API
			
C#中调用API 介绍 API( Application Programming Interface ),我想大家不会陌生,它是我们Windows编程的常客,虽然基于.Net平台的C#有了强大的类库, ...
 - js获取某个ID的class名称
			
.HTML结构 <div id = "test" class="test_class">我的类名为test_class</div> &l ...
 - div文字超出
			
效果一:div文字超出处理 <div style="width:200px; white-space:nowrap;overflow:hidden;text-overflow:elli ...
 - Linux下MySQL忘记密码
			
系统:CentOS6.6 64位 参考文档(截图请看原网址): Linux下MySQL忘记root密码怎么办_百度经验 http://jingyan.baidu.com/article/1709ad8 ...
 - 免 sudo 使用 docker
			
免 sudo 使用 docker 如果还没有 docker group 就添加一个: sudo groupadd docker 将用户加入该 group 内.然后退出并重新登录就生效啦. sudo g ...
 - SCWS分词扩展在WINDOWS下的安装方法
			
安装之前先确认您是否拥有主机的安装权限,否则无法进行安装,安装步骤如下: 1. 根据您当前用的 PHP 版本,下载相应已编译好的 php_scws.dll 扩展库. 目前支持以下版本 [PHP-4 ...
 - Nginx负载均衡配置实例详解(转)
			
负载均衡是我们大流量网站要做的一个东西,下面我来给大家介绍在Nginx服务器上进行负载均衡配置方法,希望对有需要的同学有所帮助哦. 负载均衡 先来简单了解一下什么是负载均衡,单从字面上的意思来理解就可 ...
 - PHPstorm设置连接FTP,进行文件上传、下载、比较
			
内容转载自:http://www.cnblogs.com/jikey/p/3486621.html 如何在 ...
 - 如何判断PHP 是线程安全还是非线程安全的
			
什么是线程安全与非线程安全? 线程安全就是在多线程环境下也不会出现数据不一致,而非线程安全就有可能出现数据不一致的情况. 线程安全由于要确保数据的一致性,所以对资源的读写进行了控制,换句话说增加了系统 ...
 - CF460C Present (二分 + 差分数列)
			
Codeforces Round #262 (Div. 2) C C - Present C. Present time limit per test 2 seconds memory limit p ...