- const总是修饰其右边最近元素
const char *const p = "abc";//第一个const修饰char,第二个修饰p
- 非const底层数据类型不能赋值给const底层数据,例如,
const char *pa;
char *pb;
pb = pa;//错误,底层数据不对应,可以用const_cast<char*>(pa)
容易理解错误的地方:
typedef char *pstring;
const pstring cstr = 0; //cstr是指向char的常量指针
const pstring *ps; //ps是一个指针,它的对象是指向char的常量指针
如果尝试着把类型别名替换成本来的名字后就错了
const char *cstr = 0;//是对const pstring cstr的错误理解
- typedef用法
/*去掉typedef后就是声明一个数组,名字是list
用上typedef后list就成了类型*/
typedef int list[6];
list l;
等价于
using list = int [6]; //c++11语法
list l;
- 数值成员初始化形式的构造函数和赋值形式的构造函数比较
运行效率
构造函数初始值是用形如 X(int ia, int ib) : a(ia), b(ib){}这样的语法对类的数据成员赋初始值。 参数初始化的顺序是从右边参数到左边参数。
赋值形式的构造函数形如 X(int ia, int ib) {a = ia; b = ib;} 先初始化再赋值,效率低。
构造函数的初始值有时必不可少
例如数据成员有引用或const常量时必须用初始值形式的构造函数