C語言數據類型轉換實例代碼
數據類型轉換就是將數據從一種類型轉換到另一種類型。下面就有小編分享C語言數據類型轉換實例代碼,歡迎大家學習!
例如,為了保存小數你可以將int類型的變量轉換為double類型。
數據類型轉換的一般格式為:
(type_name) expression
type_name為要轉換到的數據類型,expression為表達式。例如:
(float) a; //把a轉換為實型(int)(x+y); //把x+y的結果轉換為整型(float) 100; //將一個常量轉換為實型
【示例】將整數轉換為浮點數:
#includeint main(){ int sum = 17, count = 5; double mean; mean = (double) sum / count; printf("Value of mean : %fn", mean); return 0;}
運行結果:
Value of mean : 3.400000
需要注意的是,類型轉換運算符( )的優先級高於/ ,(double) sum / count會先將 sum 轉換為 double 類型,然後再進行除法運算。如果寫作(double) (sum / count) ,那麼運行結果就是 3.000000。
這種由程序員顯式進行的轉換稱為強制類型轉換。除了強制類型轉換,在不同數據類型的混合運算中編譯器也會隱式地進行數據類型轉換,稱為自動類型轉換。
自動類型轉換遵循下面的規則:
1.若參與運算的數據類型不同,則先轉換成同一類型,然後進行運算。
2.轉換按數據長度增加的方向進行,以保證精度不降低。例如int型和long型運算時,先把int量轉成long型後再進行運算。
3.所有的.浮點運算都是以雙精度進行的,即使僅含float單精度量運算的表達式,也要先轉換成double型,再作運算。
型和short型參與運算時,必須先轉換成int型。
5.在賦值運算中,賦值號兩邊的數據類型不同時,需要把右邊表達式的類型將轉換為左邊變量的類型。如果右邊表達式的數據類型長度比左邊長時,將丟失一部分數據,這樣會降低精度。
下圖表示了類型自動轉換的規則:
【示例】自動數據類型轉換。
#includeint main(){ float PI=3.14159; int s1, r=5; double s2; s1 = r*r*PI; s2 = r*r*PI; printf("s1=%d, s2=%fn", s1, s2); return 0;}
運行結果:
s1=78, s2=78.539753
在計算表達式r*r*PI時,r 和 PI 都轉換成double類型,表達式的結果也為double類型。但由於 s1 為整型,所以賦值運算的結果仍為整型,捨去了小數部分。
注意是將小數部分直接丟掉,而不是按照四捨五入向前舍入。
無論是強制轉換或是自動轉換,都只是為了本次運算的需要而對變量的數據長度進行的臨時性轉換,而不改變數據説明時對該變量定義的類型。
請看下面的例子:
#includeint main(){ float f=5.75; printf("(int)f=%d, f=%fn",(int)f, f); return 0;}
運行結果:
(int)f=5, f=5.750000
-
C語言如何提高程序效率
好的代碼沒有一個統一的衡量標準,在程序員們的世界裏大家也是各自按照自己的標準衡量着自己和別人的代碼。不過有一個標準幾乎是被所有人認同的。服役時間越長、出錯率越高的代碼就是好代碼。所有的編程方法、代碼技巧甚至於設計模式都是為了達到這個目的而產生...
-
C語言與JAVA的區別
很多人不明白C語言與C++和JAVE之間的區別,為此,為大家收集整理了下面的內容,歡迎閲讀!C語言C語言是一門通用計算機編程語言,應用廣泛。C語言的設計目標是提供一種能以簡易的方式編譯、處理低級存儲器、產生少量的機器碼以及不需要任何運行環境支持便能運行的編程語...
-
C語言自增(++)和自減(--)
C語言源自KenThompson發明的B語言,那麼大家知道C語言自增(++)和自減(--)是什麼呢?下面一起來看看!一個整數自身加一可以這樣寫:a+=1;它等價於a=a+1;。但是在C語言中還有一種更簡單的寫法,就是a++;或者++a;。這種寫法叫做自加或自增;意思很明確,就是自身加一。相應...
-
C語言轉義字符和格式控制符參考
導語:字符型常量所表示的值是字符型變量所能包含的值。我們可以用ASCII表達式來表示一個字符型常量,或者用單引號內加反斜槓表示轉義字符。下面是C語言轉義字符和格式控制符參考,歡迎學習:轉義字符參考:a:蜂鳴,響鈴:回退:向後退一格f:換頁:換行,光標到下行行首:回車,光...