1. 程式人生 > >C語言強制型別轉換

C語言強制型別轉換

字元型變數的值實質上是一個8位的整數值,因此取值範圍一般是-128~127,char型變數也可以加修飾符unsigned,則unsigned char 型變數的取值範圍是0~255(有些機器把char型當做unsighed char型對待, 取值範圍總是0~255)。
如果一個運算子兩邊的運算數型別不同,先要將其轉換為相同的型別,即較低型別轉換為較高型別,然後再參加運算,轉換規則如下圖所示。

double ← float

long

unsigned

int ← char,short

圖中橫向箭頭表示必須的轉換,如兩個float型數參加運算,雖然它們型別相同,但仍要先轉成double型再進行運算,結果亦為double型。縱向箭頭表示當運算子兩邊的運算數為不同型別時的轉換,如一個long 型資料與一個int型資料一起運算,需要先將int型資料轉換為long型, 然後兩者再進行運算,結果為long型。所有這些轉換都是由系統自動進行的, 使用時你只需從中瞭解結果的型別即可。這些轉換可以說是自動的,當然,C語言也提供了以顯式的形式強制轉換型別的機制。

當較低型別的資料轉換為較高型別時,一般只是形式上有所改變,而不影響資料的實質內容, 而較高型別的資料轉換為較低型別時則可能有些資料丟失。

賦值中的型別轉換
當賦值運算子兩邊的運算物件型別不同時,將要發生型別轉換,轉換的規則是:把賦值運算子右側表示式的型別轉換為左側變數的型別。具體的轉換如下:
(1) 浮點型與整型
將浮點數(單雙精度)轉換為整數時,將捨棄浮點數的小數部分,只保留整數部分。
將整型值賦給浮點型變數,數值不變,只將形式改為浮點形式,即小數點後帶若干個0。注意:賦值時的型別轉換實際上是強制的。

(2) 單、雙精度浮點型
由於C語言中的浮點值總是用雙精度表示的,所以float 型資料只是在尾部加0延長為doub1e型資料參加運算,然後直接賦值。doub1e型資料轉換為float型時,通過截尾數來實現,截斷前要進行四捨五入操作。

(3) char型與int型
int型數值賦給char型變數時,只保留其最低8位,高位部分捨棄。
char型數值賦給int型變數時,一些編譯程式不管其值大小都作正數處理,而另一些編譯程式在轉換時,若char型資料值大於127,就作為負數處理。對於使用者來講,如果原來char型資料取正值,轉換後仍為正值;如果原來char型值可正可負,則轉換後也仍然保持原值,只是資料的內部表示形式有所不同。

(4) int型與1ong型
long型資料賦給int型變數時,將低16位值送給int型變數,而將高16 位截斷捨棄。(這裡假定int型佔兩個位元組)。
將int型資料送給long型變數時,其外部值保持不變,而內部形式有所改變。

(5) 無符號整數
將一個unsigned型資料賦給一個佔據同樣長度儲存單元的整型變數時(如:unsigned→int、unsigned long→long,unsigned short→short) ,原值照賦,內部的儲存方式不變,但外部值卻可能改變。
將一個非unsigned整型資料賦給長度相同的unsigned型變數時,內部儲存形式不變,但外部表示時總是無符號的。
將一個char轉換為unsigned int型別,首先char型別資料轉換為int型別,然後再轉換為unsigned int,即按照轉換規則圖進行轉換。