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