程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C >> C語言基礎知識 >> C語言數據類型轉換

C語言數據類型轉換

編輯:C語言基礎知識
數據類型轉換就是將數據(變量、表達式的結果)從一種類型轉換到另一種類型。例如,為了保存小數你可以將int類型的變量轉換為double類型。

數據類型轉換的一般格式為:
(type_name) expression
type_name為要轉換到的數據類型,expression為表達式。例如:
(float) a;  //把a轉換為實型
(int)(x+y);  //把x+y的結果轉換為整型
(float) 100;  //將一個常量轉換為實型
【示例】將整數轉換為浮點數:
#include <stdio.h>
int main(){
   int sum = 17, count = 5;
   double mean;
   mean = (double) sum / count;
   printf("Value of mean : %f\n", 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型,再作運算。
  4. char型和short型參與運算時,必須先轉換成int型。
  5. 在賦值運算中,賦值號兩邊的數據類型不同時,需要把右邊表達式的類型將轉換為左邊變量的類型。如果右邊表達式的數據類型長度比左邊長時,將丟失一部分數據,這樣會降低精度。

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

【示例】自動數據類型轉換。
#include<stdio.h>
int main(){
    float PI=3.14159;
    int s1, r=5;
    double s2;
    s1 = r*r*PI;
    s2 = r*r*PI;
    printf("s1=%d, s2=%f\n", s1, s2);
    return 0;
}
運行結果:
s1=78, s2=78.539753

在計算表達式r*r*PI時,r 和 PI 都轉換成double類型,表達式的結果也為double類型。但由於 s1 為整型,所以賦值運算的結果仍為整型,捨去了小數部分。
注意是將小數部分直接丟掉,而不是按照四捨五入向前捨入。

無論是強制轉換或是自動轉換,都只是為了本次運算的需要而對變量的數據長度進行的臨時性轉換,而不改變數據說明時對該變量定義的類型。請看下面的例子:
#include<stdio.h>
int main(){
    float f=5.75;
    printf("(int)f=%d, f=%f\n",(int)f, f);
    return 0;
}
運行結果:
(int)f=5, f=5.750000
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved