按照資料類型佔用儲存不同可以自動類型轉換或強制類型轉換,總的原則是小儲存容量資料類型可以自動轉換成為大儲存容量資料類型。
不同類型資料間按照下面關係的從左至右(從低到高)自動轉換,
_Bool 、 char 、 short int 、枚舉類型 -> int ->long int->long long-> float -> double -> long double 。
如果這些資料類型進行混合運算,運算中不同類型的資料先轉化為同一類型,然後進行運算,轉換從左至右自動轉換,如表 2-3 所示。
表 2-3 類型轉換先後順序表
運算元 1 類型 |
運算元 2 類型 |
轉換後的類型 |
_Bool 、 char 、 short int 、枚舉類型 |
int |
int |
_Bool 、 char 、 short int 、枚舉類型、 int |
long int |
long int |
_Bool 、 char 、 short int 、枚舉類型、 int 、 long int |
long long |
long long |
_Bool 、 char 、 short int 、枚舉類型、 int 、 long int 、 long long |
float |
float |
_Bool 、 char 、 short int 、枚舉類型、 int 、 long int 、 long long 、 float |
double |
double |
_Bool 、 char 、 short int 、枚舉類型、 int 、 long int 、 long long 、 float 、 double |
long double |
long double |
如果有下面的表示式,其中, f 是 float 類型, i 為 int 類型, l 為 long int 類型, s 為 short int 類型,結果是什麼類型?
f * i + l /s
運行結果為 float 類型,這是因為 f 是 float 其它的運算元與 float 運算其結果就是 float 類型。
如果遵守類型轉換是右到左情況,就需要強制類型轉換 了,強制類型轉換文法形式上很簡單,就是在資料前面加上(目標類型),但是這種轉換是存在風險的,有可能造成資料的丟失,需要謹慎進行。例如:
long int l = 6666666666;
NSLog(@"l = %li",l);
int i = (int)l;
NSLog(@"i = %i",i);
啟動並執行結果是,其中 6666666666 數值已經超出了 int 類型的容量,因此出現了資料的丟失。
l = 6666666666
i = -1923267926
強制轉換有的時候嵌入在其它的運算式裡面,它會與啟動並執行優先順序交織在一起,情況就會變的更加複雜,假設有下面的幾條語句:
int total = 3446;
int n = 6;
float average = total / n;
運行完成 float 的變數 average 結果是 574 ,小數點內容被截取掉了,如果我們採用下面的語句實現:
int total = 3446;
int n = 6;
float average = (float)total / n;
運行完成 float 的變數 average 結果是 574.333 ,這個資料要比上面計算的精確,這是因為 (float)total 先把 int 類型的 total 變數轉換成為 float 類型的 total 變數。