【c++11】总结auto和decltype

本文深入探讨了C++中的auto和decltype关键字的功能与用法,包括类型推断规则、顶层const处理方式以及如何正确使用这些特性来声明变量。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.auto 表达式类型推断

auto i=0,*p=&ii

该例中i为int,p为int型指针,auto可以一条语句声明多个变量,但是所有变量初始类型都需一样。

auto i=0,j=3.14;//错误,两个变量类型不一样

auto会忽略顶层const,只保留底层const,之前一篇博文也提到了,ps:constexpr则只对指针有效,顶层。

const int ci=i;
auto b=ci;
此时,b为一个整数,顶层const被忽略掉,如果非要声明顶层const,可以这样写:
auto b=&ci;//对常量取地址是一种底层const
对常量取地址是一种底层const!

2.decltype 如果想从表达式推断变量类型,但却并不用该值初始化(与auto区别),使用decltype。

decltype处理顶层const和引用的方式与auto不同:

const int ci=0,&cj=ci;
decltype(ci)x = 0;//x为const int
decltype(cj)y = x;//y是const int&,y绑定到x
decltype(cj)z;//错误,cj是一个引用,必须初始化

引用从来都是作为其所指对象的同义词出现,只是在decltype处是一个例外,返回引用类型。

int i=42,*p=&i,&r=i;
decltype(r+0)b;
decltype(*p)c;

在上述例子中,r为一个int&类型,但+0之后,表达式的结果是一个具体值,b是一个int;表达式内容是一个解引用操作,c的类型是int,而不是int&。

int i=42;
decltype((i))d;

此时,d为int&,必须初始化。加双层括号的decltype得到的类型永远是引用!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值