第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類型。