1.字符文字前面可以加“L ” ,这称为宽字符文字,类型为wchar_t 。宽字符常量用来支持某些语言的字符集合,如汉语、日语。这些语言中的某些字符不能用单个字符来表示
例:宽字符文字:L'a' 宽字符串文字:L"a wide string literal"
2.c风格的字符串可以直接转换为string对象。而string对象则不能直接转换为c风格的字符串,为实现这种转换,可以显式的的调用c_str()函数,用法如下:
const char *str = s1.c_str(); //注意:c_str函数返回的是指向常量数组的指针,不能赋值给变量。
3.const限定符将一个对象转换为常量,常量一旦定义就无法改变,故必须初始化。若对一个常量使用指针,必须使用指向常量的指针:
const double *ptr; //注意:ptr为指向常量的指针,而ptr不是常量,可以重新赋值,改变指向的对象,但无法改变指向的对象的内容。
const对象的地址只能赋值给指向const对象的指针,而指向const对象的指针则可以指向非const对象。
在实际的程序中指向const 的指针常被用作函数的形式参数,它作为一个约定来保证被传递给函数的实际对象在函数中不会被修改。
4.容器vector不能被显式的初始化,但可以将其初始化为一个数组的全部或一部分,只需指定要使用的数组的初始地址和末尾地址的下一位即可:
int a=[10]={1};
vector<int> vec(a,a+6); //注意:此处要拷贝的元素为:a[0]到a[5]六个元素。
但对于两个vector而言,一个vector可以被另一个vector初始化或赋值。
5.typedef不同于宏扩展,例:
typedef char * cstring;
extern const cstring cstr;
对此,cstr的类型是什么?
根据定义可知,const修饰的是cstring,而cstring是个指针,因此,cstr是一个指向字符的const指针:char *const cstr; 而非指向const字符的指针:const char* cstr。
6.volatile 修饰符的主要目的是提示编译器,该对象的值可能在编译器未监测到的情况下被改变,因此编译器不能武断地对引用这些对象的代码作优化处理。其用法同const相似,都是作为类型的附加修饰符。