第1⑵章 变量和基本类型
1.下面这个语句在C++98和C++11中的输出结果不同.
C++98结果:
(如果想要更高的精度,可以用%.9lf,输出9位有效数字)
C++11结果:
结论:
printf的%lf在C++11中表示longdouble,所以用中%f就能够输出float和double类型.而printf在C++98中可以用%lf正确输出double.
如果是scanf的话,不论C++98还是C++11中float都用%f读取,double都用%lf读取,由于2者结构不同.
2. 默许初始化
定义变量时没有指定初值,变量被默许初始化.
内置类型:如果是全局的(变量),那末就初始为0.如果是局部的,那末值不肯定.
2.1如果该类的默许构造函数不支持定义对象不给定初值,那末就报错.
2.2如果支持定义对象不给初值,那末就履行默许构造函数的初始化.
2.3如果该类用的是合成的默许构造函数,那末就履行默许初始化.默许初始化时,对成员是对象的履行它的默许构造函数(有点递归的意思),对成员是内置类型的履行默许初始化(全局置0,局部未定义)
上面的结果可以看出,s成员始终都是空串.而a对象和b对象的int a和 int b成员 由于位置不同,值也不同.
3. 如何定义1个指向指针的援用:
4. const变量是仅在当前文件内有效的,那末我们如何定义且使用全局const呢?
在1个文件如 extern const int a=100;定义,在其他所有需要用到a的文件内声明如 extern const int a;
Add.h文件
Add.cpp文件
main.cpp文件
其实这个与我们第1章定义全局变量有点类似.
5. auto与decltype用法的区分。
auto会消除顶层const,decltype不会。
对援用类型,auto得到1个普通类型,decltype得到援用。
decltype((i))时得到的是i类型的援用,decltype(i)得到i类型。