C++11新特性

本文详细介绍了C++11中的新特性——auto和decltype。auto作为类型指示符,用于简化变量声明,但不能用于函数参数、非静态成员变量定义和数组定义。decltype则能从表达式直接获取类型,且不改变表达式的cv限定。总结了auto的推导规则以及其限制,展示了在泛型编程和迭代器使用中的优势。

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

C++11新特性

auto
auto 并不能代表一个实际的类型声明,只是一个类型
声明的占位符
使用auto声明的变量必须马上初始化,以让编译器推断出
它的实际类型,并在编译时将auto占位符替换为真正的类型;

旧标准auto是具有自动存储期的局部变量,在新标准中作为类型指示符;
auto int i = 0;

int x = 0;
const auto e = x;//e->const int
auto f = e;//f->int,原因:当表达式带有const属性时,
auto会把const属性抛弃掉,推导成non-const类型int;

const auto& g= x;
auto& h = g;//推导出h->const int&,当auto和引用结合时
auto的推导将保留表达式的const属性;
结论
1.当不声明为指针或引用时,auto的推导结果和初始化表达式
抛弃引用和cv(const、volatile)限定符后类型一致;
2.当声明为指针或引用时,auto的推导结果将保持初始化表达式的csv属性;
3.auto的限制
不能用于函数的参数
void func(auto a);

不能用于非静态成员变量,auto编译阶段进行类型推导,非静态成员变量编译时变量
还没有进行初始化
struct foo{
auto var1=0;//error
static const auto var2=0;//ok,var2->static const int;
};
无法定义数组
int arr[10]={0};
auto aa=arr;//ok,aa->int*
auto rr[10]=arr;//error,auto无法定义数组

无法推导出模板参数
Bar bar;
Bar bb=bar;//error,auto无法推导出模板参数

1.一般用于iterator迭代器类型声明
2.定义一个泛型函数func,多个类中都有
get()静态返回值函数,但返回类型不同,若想在
func中调用get函数并获取其返回值,需要使用auto进行
变量类型声明;

decltype
decltype(exp)
可以通过表达式推出它的类型本身,和auto不同之处是auto只能
根据变量的初始化表达式推导出变量具有的类型,若想通过某个表达式
得到类型,但不希望新新变量和这个表达式具有相同的值,decltype就派上用场了;
和auto相同处是都可以加上指针、引用、cv限定符;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值