C++学习笔记02-constexpr和const和typedef和decltype和auto

c++中被const修饰的将视为常量,而不是只读的变量

constexpr

把变量声明为constexpr等价于把该变量声明为常量,而且该变量必须要用常量表达式初始化
并且和const,引用的初始化一样,必须在声明的时候就初始化,否则编译报错

constexpr int a = 1;
int const a = 1;等价声明

注:constexpr是把变量给const了,例如下面的指针声明

int i = 0 ;
constexpr int * p = &i;
int * const p = &i;等价声明

以前常犯的typedef毛病

char ch = 'a';
typedef char *ptr_ch;
const ptr_ch  p;正确声明了一种类型为char*的常量指针,p是常量
constexpr char* p;直接把p给const,等价于上面的const ptr_ch p;声明
我以前对typedef的错误理解:
我之前会将ptr_ch代换成为char* , 然后理解成const char (*p);错误的理解成了*p是常量而p是变量
其实应该是理解成为const (char*) p; 而不是理解成 const char (*p)

decltype

decltype(变量), decltype(表达式)用于得到某个表达式或者变量的类型,来声明某种类型的变量
注①:decltype会保留顶层const和引用(&)修饰符(与auto不同!!)
注②:decltype(*p)会返回p指向的类型的引用,而不是p指向的数据类型
注③:decltype((多重括号表达式))永远返回特定类型的引用,

auto

注①:忽略顶层const,保留底层const

顶层const和底层const的具体说明在以前写的博客里面有
C++学习笔记01-顶层const和底层const

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阿维的博客日记

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值