記得剛學C語言的時候,對那些double,float,long,unsigned int各種混亂,基本是隨便用,對數據類型沒有一個整體的框架。最近學習<<C++ primer plus>>一書,清晰了許多。於此以讀書筆記的形式記錄關於C++基本數據類型的知識。
C++ Primer Plus 第6版 中文版 清晰有書簽PDF+源代碼 http://www.linuxidc.com/Linux/2014-05/101227.htm
高度概括,C++數據類型只有兩種,整型與浮點型.
一,整數:
就是沒有小數部分的數字(除bool外按寬度遞增排序).它包括:
其中除bool外每種類型都有符號版本與無符號版本.共11種.
兩種較為特殊的情況
unsigned與signed:
當數值不會為負時,比如生命值,人口數量等,可以使用無符號類型,可以增大變量的最大儲存值.
例如:short表示的范圍為-32768到+32767 則unsigned版本為0-65535
整型如此之多,那麼,如何選擇整數類型:
二,浮點數:
能夠表示帶小數部分的數字
浮點的意思:
諸如2.5,3.15159之類的數字,計算機將其分為兩部分進行儲存.一部分表示值,另一部分用於對數值進行縮放.
例如:34.125與3412.5它們除了小數點位置不同之外,數字都相同.可以把第一個數字看成0.34125(基准值)放大100倍,第二個數看成0.34125放大10000倍.縮放因子的作用是移動小數點的位置,浮點因此得名.
C++中浮點類型有以下3種:
這三種有效位數可以一樣多,通常,float為32位,double為64位,long double為80,96或者128位.
如何選擇浮點數類型:
在在代碼中對浮點數據類型直接使用== 、<= 、>=、 !=等運算符進行比較都是不正確的。正確的方法應該是 將其差或和於小數進行比較
通常與10^6 比如浮點數與零的比較:
等於0關系: fabs(i)<=1e-6
大於0關系: i>1e-6
小於0關系: i<1e-6