您好,登錄后才能下訂單哦!
c語言數據類型轉換的方式有哪些?相信有很多人都不太了解,今天小編為了讓大家更加了解c語言數據類型轉換的方式,所以給大家總結了以下內容,一起往下看吧。
c語言數據類型轉換的方法
數據類型轉換就是將數據(變量、數值、表達式的結果等)從一種類型轉換為另一種類型。
自動類型轉換
自動類型轉換就是編譯器默默地、隱式地、偷偷地進行的數據類型轉換,這種轉換不需要程序員干預,會自動發生。
1) 將一種類型的數據賦值給另外一種類型的變量時就會發生自動類型轉換,例如:
float f = 100;
100 是 int 類型的數據,需要先轉換為 float 類型才能賦值給變量 f。再如:
int n = f;
f 是 float 類型的數據,需要先轉換為 int 類型才能賦值給變量 n。
在賦值運算中,賦值號兩邊的數據類型不同時,需要把右邊表達式的類型轉換為左邊變量的類型,這可能會導致數據失真,或者精度降低;所以說,自動類型轉換并不一定是安全的。對于不安全的類型轉換,編譯器一般會給出警告。
2) 在不同類型的混合運算中,編譯器也會自動地轉換數據類型,將參與運算的所有數據先轉換為同一種類型,然后再進行計算。轉換的規則如下:
轉換按數據長度增加的方向進行,以保證數值不失真,或者精度不降低。例如,int 和 long 參與運算時,先把 int 類型的數據轉成 long 類型后再進行運算。
所有的浮點運算都是以雙精度進行的,即使運算中只有 float 類型,也要先轉換為 double 類型,才能進行運算。
char 和 short 參與運算時,必須先轉換成 int 類型。
下圖對這種轉換規則進行了更加形象地描述:
unsigned 也即 unsigned int,此時可以省略 int,只寫 unsigned。
自動類型轉換示例:
#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.539749
在計算表達式r*r*PI時,r 和 PI 都被轉換成 double 類型,表達式的結果也是 double 類型。但由于 s1 為整型,所以賦值運算的結果仍為整型,舍去了小數部分,導致數據失真。
今天小編給大家分享的是c語言數據類型轉換的方式有哪些,相信很多人都不太了解,為了讓大家更加了解c語言數據類型轉換的方式,所以給大家總結了以下內容,一起往下看吧。一定會有所收獲的哦。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。