c++碎片小知识

一.auto

1.复杂的类型名称

如上,这样的类型名字太长,容易出错,大多数同学都能想到typedef,这样想没问题,但是typedef会有一个新的难题,如下:

这两句正确吗?显然,第一句编译不通过。

你以为const pstring 等价于const pstring*吗?不是的这里的const实际上修饰的是p1,也就是说等价于pstring* const,所以p1指针就是一个常量,所以在使用前必须初始化。

分析到这里就可猜出来第二句能够编译通过了。为什么呢?根据形式,可以看出这里的const修饰的是*p2,也就是说,这里的const修饰的是二级指针指向的内容,所以p2依然是个变量,暂时没有初始化也没关系,编译可以通过

所以说,在这种场景下,编译器不会把typedef进行简单的替换。

2.auto使用

1.auto与指针和引用结合

在定义指针时,使用auto或auto*都没有区别,但是在定义引用类型时,必须使用auto&

这里的typeid用来获取表达式/数据类型的类型信息,typeid与sizeof一样,都是操作符,而不是函数。

name()用来返回当前的类型名称

raw_name() 用来返回名字编码(NameMangling)算法产生的新名称。

hash_code() 用来返回当前类型对应的 hash 值,是标识当前类型的整数。

2.在同行定义多个变量

当在同行定义多个变量时,这些变量必须是相同的类型,否则会报错

3.auto不能推导的场景

1.auto不能进行函数参数的推导

2.auto不能直接用来声明数组

二.范围for

如上的for循环可以简化为

注意这里与引用的结合

三.指针空值nullptr

C语言中我们一般都是用NULL。NULL是一个宏定义,在stddef.h头文件中

由文件可知,NULL可能被定义成0,也可能是(void*)0.不论采取何种定义方式,都可能在某些场景下出现问题:

但要是改成nullptr就不会出错了。

nullptr就专门表示指针空值,不再是什么宏定义/宏替换。

使用nulptr时不需要引入头文件,因为它是一个关键字。

sizeof(nullptr)与sizeof((void*)0)一样。

为了提高代码健壮性,最好使用nullptr

相关推荐
感哥7 小时前
C++ 面向对象
c++
沐怡旸8 小时前
【底层机制】std::shared_ptr解决的痛点?是什么?如何实现?如何正确用?
c++·面试
感哥15 小时前
C++ STL 常用算法
c++
saltymilk1 天前
C++ 模板参数推导问题小记(模板类的模板构造函数)
c++·模板元编程
感哥1 天前
C++ lambda 匿名函数
c++
沐怡旸1 天前
【底层机制】std::unique_ptr 解决的痛点?是什么?如何实现?怎么正确使用?
c++·面试
感哥1 天前
C++ 内存管理
c++
博笙困了2 天前
AcWing学习——双指针算法
c++·算法
感哥2 天前
C++ 指针和引用
c++
感哥2 天前
C++ 多态
c++