在c語言中,可以透過「(新型別名稱) 資料或運算式」語句來進行強制型別轉換;例如「(float) 100」就是將數值100(預設為int型別)轉換為float型,「(int)(x y)」就是將表達式「x y」的結果轉換為int整數型。
本教學操作環境:windows7系統、c99版本、Dell G3電腦。
資料型別轉換就是將資料(變數、數值、表達式的結果等)從一種型別轉換成另一種型別。
c語言有兩種資料型別方式:
自動型別轉換:就是編譯器默默地、隱式地、偷偷地進行的資料型別轉換,這種轉換不需要程式設計師幹預,會自動發生。
強制類型轉換
自動類型轉換是編譯器根據程式碼的上下文環境自行判斷的結果,有時並不是那麼「智能”,不能滿足所有的需求。如果需要,程式設計師也可以自己在程式碼中明確地提出要進行型別轉換,稱為強制型別轉換。
自動型別轉換是編譯器默默地、隱式地進行的一種型別轉換,不需要在程式碼中體現;強制型別轉換是程式設計師明確提出的、需要透過特定格式的程式碼來指明的一種類型轉換。換句話說,自動類型轉換不需要程式設計師幹預,強制類型轉換必須有程式設計師幹預。
強制型別轉換的格式為:
(type_name) expression
type_name為新型別名稱,expression為表達式。例如:
(float) a; //将变量 a 转换为 float 类型 (int)(x+y); //把表达式 x+y 的结果转换为 int 整型 (float) 100; //将数值 100(默认为int类型)转换为 float 类型
下面是一個需要強制類型轉換的經典例子:
#include <stdio.h> int main(){ int sum = 103; //总数 int count = 7; //数目 double average; //平均数 average = (double) sum / count; printf("Average is %lf!\n", average); return 0; }
運行結果:
Average is 14.714286!
sum 和count 都是int 類型,如果不進行幹預,那麼sum / count
的運算結果也是int 類型,小數部分將被丟棄;雖然是average 是double 類型,可以接收小數部分,但是心有餘力不足,小數部分提前就被「閹割」了,它只能接收到整數部分,這會導致除法運算的結果嚴重失真。
既然 average 是 double 類型,為何不充分利用,盡量提高運算結果的精確度呢?為了達到這個目標,我們只要將 sum 或 count 其中之一轉換為 double 類型即可。在上面的程式碼中,我們將 sum 強制轉換為 double 類型,這樣sum / count
的結果也會變成 double 類型,就可以保留小數部分了,average 接收到的值也會更精確。
在這段程式碼中,有兩點要注意:
對於除法運算,如果除數和被除數都是整數,那麼運算結果也是整數,小數部分將直接丟棄;如果除數和被除數其中有一個是小數,那麼運算結果也是小數。
( )
的優先權高於/
,對於表達式(double) sum / count
,會先執行(double) sum
,將sum 轉換為double 類型,然後再進行除法運算,這樣運算結果也是double 類型,能夠保留小數部分。注意不要寫(double) (sum / count)
,這樣寫運算結果將是 3.000000
,仍然不能保留小數部分。
相關推薦:《C語言影片教學》
以上是c語言怎麼進行強制型別轉換的詳細內容。更多資訊請關注PHP中文網其他相關文章!