C語言資料型別轉換

2021-08-06 02:55:53 字數 1543 閱讀 9816

資料型別轉換就是將資料(變數、表示式的結果)從一種型別轉換到另一種型別。例如,為了儲存小數你可以將int型別的變數轉換為double型別。

資料型別轉換的一般格式為:

(type_name) expression
type_name為要轉換到的資料型別,expression為表示式。例如:

(float) a;  //把a轉換為實型

(int)(x+y); //把x+y的結果轉換為整型

(float) 100; //將乙個常量轉換為實型

【示例】將整數轉換為浮點數:
#include int main()
執行結果:

value of mean : 3.400000

需要注意的是,型別轉換運算子( )的優先順序高於/(double) sum / count會先將 sum 轉換為 double 型別,然後再進行除法運算。如果寫作(double) (sum / count),那麼執行結果就是 3.000000。

這種由程式設計師顯式進行的轉換稱為強制型別轉換。除了強制型別轉換,在不同資料型別的混合運算中編譯器也會隱式地進行資料型別轉換,稱為自動型別轉換

自動型別轉換遵循下面的規則:

若參與運算的資料型別不同,則先轉換成同一型別,然後進行運算。

轉換按資料長度增加的方向進行,以保證精度不降低。例如int型和long型運算時,先把int量轉成long型後再進行運算。

所有的浮點運算都是以雙精度進行的,即使僅含float單精度量運算的表示式,也要先轉換成double型,再作運算。

char型和short型參與運算時,必須先轉換成int型。

在賦值運算中,賦值號兩邊的資料型別不同時,需要把右邊表示式的型別將轉換為左邊變數的型別。如果右邊表示式的資料型別長度比左邊長時,將丟失一部分資料,這樣會降低精度。

下圖表示了型別自動轉換的規則:

【示例】自動資料型別轉換。

#includeint main()
執行結果:

s1=78, s2=78.539753

在計算表示式r*r*pi時,r 和 pi 都轉換成double型別,表示式的結果也為double型別。但由於 s1 為整型,所以賦值運算的結果仍為整型,捨去了小數部分。

注意是將小數部分直接丟掉,而不是按照四捨五入向前捨入。
無論是強制轉換或是自動轉換,都只是為了本次運算的需要而對變數的資料長度進行的臨時性轉換,而不改變資料說明時對該變數定義的型別。請看下面的例子:

#includeint main()
執行結果:

(int)f=5, f=5.750000

原文:

C語言資料型別轉換

自動轉換發生在不同資料型別的量混合運算時,由編譯系統自動完成。自動轉換遵循以下規則 若參與運算量的型別不同,則先轉換成同一型別,然後進行運算。轉換按資料長度增加的方向進行,以保證精度不降低。如int型和long型運算時,先把int量轉成long型後再進行運算。所有的浮點運算都是以雙精度進行的,即使僅...

C語言資料型別轉換

變數的資料型別是可以轉換的。轉換的方法有兩種,一種是自動轉換,一種是強制轉換。自動轉換發生在不同資料型別的量混合運算時,由編譯系統自動完成。自動轉換遵循以下規則 若參與運算量的型別不同,則先轉換成同一型別,然後進行運算。轉換按資料長度增加的方向進行,以保證精度不降低。如int型和long型運算時,先...

C語言 資料型別轉換

資料型別轉換分為兩種,一種為隱式轉換 預設轉換 另一種為顯式轉換 強制轉換 隱式轉換就是編譯器默默地偷偷地進行的資料型別轉換,這種轉換不需要程式設計師干預,會自動發生。但隱式轉換不能滿足所有的需求。需要時,程式設計師也可以自己在 中明確地提出要進行型別轉換,這稱為強制型別轉換。一 c語言資料型別 二...