天天看點

objective-C 資料類型轉換

 按照資料類型占用存儲不同可以自動類型轉換或強制類型轉換,總的原則是小存儲容量資料類型可以自動轉換成為大存儲容量資料類型。

不同類型資料間按照下面關系的從左到右(從低到高)自動轉換,

_Bool 、 char 、 short int 、枚舉類型 -> int ->long int->long long-> float -> double -> long double 。

如果這些資料類型進行混合運算,運算中不同類型的資料先轉化為同一類型,然後進行運算,轉換從左到右自動轉換,如表 2-3 所示。

表 2-3 類型轉換先後順序表

操作數 1 類型

操作數 2 類型

轉換後的類型

_Bool 、 char 、 short int 、枚舉類型

int

_Bool 、 char 、 short int 、枚舉類型、 int

long int

_Bool 、 char 、 short int 、枚舉類型、 int 、 long int

long long

_Bool 、 char 、 short int 、枚舉類型、 int 、 long int 、 long long

float

_Bool 、 char 、 short int 、枚舉類型、 int 、 long int 、 long long 、 float

double

_Bool 、 char 、 short int 、枚舉類型、 int 、 long int 、 long long 、 float 、 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 ,小數點内容被截取掉了,如果我們采用下面的語句實作:

float average = (float)total / n;

運作完成 float 的變量 average 結果是 574.333 ,這個資料要比上面計算的精确,這是因為 (float)total 先把 int 類型的 total 變量轉換成為 float 類型的 total 變量。

     本文轉自 驿落黃昏 51CTO部落格,原文連結:http://blog.51cto.com/yiluohuanghun/1153588,如需轉載請自行聯系原作者