強制類型轉換是把變量從一種類型轉換為另一種數據類型。例如,如果您想存儲一個 long 類型的值到一個簡單的整型中,您需要把 long 類型強制轉換為 int 類型。您可以使用強制類型轉換運算符來把值顯式地從一種類型轉換為另一種類型,如下所示:
(type_name) expression
請看下面的實例,使用強制類型轉換運算符把一個整數變量除以另一個整數變量,得到一個浮點數:
#include <stdio.h> main() { int sum = 17, count = 5; double mean; mean = (double) sum / count; printf("Value of mean : %f\n", mean ); }
當上面的代碼被編譯和執行時,它會產生下列結果:
Value of mean : 3.400000
這裡要注意的是強制類型轉換運算符的優先級大於除法,因此 sum 的值首先被轉換為 double 型,然後除以 count,得到一個類型為 double 的值。
類型轉換可以是隱式的,由編譯器自動執行,也可以是顯式的,通過使用強制類型轉換運算符來指定。在編程時,有需要類型轉換的時候都用上強制類型轉換運算符,是一種良好的編程習慣。
整數提升是指把小於 int 或 unsigned int 的整數類型轉換為 int 或 unsigned int 的過程。請看下面的實例,在 int 中添加一個字符:
#include <stdio.h> main() { int i = 17; char c = 'c'; /* ascii 值是 99 */ int sum; sum = i + c; printf("Value of sum : %d\n", sum ); }
當上面的代碼被編譯和執行時,它會產生下列結果:
Value of sum : 116
在這裡,sum 的值為 116,因為編譯器進行了整數提升,在執行實際加法運算時,把 'c' 的值轉換為對應的 ascii 值。
常用的算術轉換是隱式地把值強制轉換為相同的類型。編譯器首先執行整數提升,如果操作數類型不同,則它們會被轉換為下列層次中出現的最高層次的類型:
常用的算術轉換不適用於賦值運算符、邏輯運算符 && 和 ||。讓我們看看下面的實例來理解這個概念:
#include <stdio.h> main() { int i = 17; char c = 'c'; /* ascii 值是 99 */ float sum; sum = i + c; printf("Value of sum : %f\n", sum ); }
當上面的代碼被編譯和執行時,它會產生下列結果:
Value of sum : 116.000000
在這裡,c 首先被轉換為整數,但是由於最後的值是 double 型的,所以會應用常用的算術轉換,編譯器會把 i 和 c 轉換為浮點型,並把它們相加得到一個浮點數。