當前位置:才華齋>計算機>C語言>

C語言基礎之資料型別轉換

C語言 閱讀(1.83W)

深入學習C語言時,有必要先了解一下資料型別的概念,以及它們之間的混合運算與型別轉換。下面就有小編分享C語言基礎之資料型別轉換,歡迎大家學習!

C語言基礎之資料型別轉換

int x; long y = 123456789101112; x = (int)y; eLine(x);

輸出結果:

我們知道long型別的取值範圍是-9223372036854775805~+9223372036854775807;int型別的是:-2147483648~+2147483647

上面的程式碼中,由於long變數的值超過了int能容納的最大值,造成了資料的丟失;像這樣有可能造成資料丟失或引發異常的任何轉換都需要執行顯式轉換(explicit);

相反的就是執行隱式轉換(implicit).

用chencked檢查上面的程式碼

從圖得知上面的轉換丟擲了一個溢位異常,顯式轉換都可能不安全, (強扭的瓜就是不甜);但是如果

long的值在int的有效值範圍內,這樣是不會引發異常的.

下面我們再來看個例子:

int i; double d = 6.88; i = (int)d; eLine(i);

輸出結果:6

像這樣發生精度丟失的我們可以把他叫做窄化轉換,C#與C或C++不同,在C或C++中是可以直接將i=d的.C#的編譯器告訴我們,如果接受精度損失,你就得用顯式型別轉換.

為什麼我們初始化float型別的時候數字的後面都要在數值後面加"F"; 因為C#認為像2.3這樣的帶小數點的常量是擁有更高精度的double型別,編譯器將因為損失精度

而拒絕而執行。所以在給float賦值時要麼顯式的將常量轉換成float的值,要麼直接在常量的後面加"F"(小寫的也可以).當然我們一般在處理浮點數的'時候最好還是直接使用

double這樣就能避免很多型別轉換.

現在我們換種方式:

像這樣把低精度的值賦給高精度變數,我們就把他叫做寬化轉換。

下面來簡單說說顯式轉換的一些限制:

在值型別中,只能在數字、字元(char)、列舉(enum)中轉換;

不能把bool直接轉換成其他型別,其他型別特不能直接轉換成bool型別.

第二部分:字串與值型別的轉換

主要是用到: Parse(),Convert,ToString()

string =》值型別 :

string aa = "123"; int num = e(aa); double db = e(aa);

當然parse方法還有很多過載方法,我就不一一列出來了

Convert是不可擴充套件的,只支援預定義數量的型別;他允許從任何基本型別轉換到其他的基本型別

string str = "true"; bool b = olean(str) ? e(str) : false; eLine(b);

輸出結果:True

TryParse聽說這個東西在1.0版本的時候只有double才有,從2.0才普及的;TryParse()用法也和Parse()方法差不多,只是他返回的是bool值,通過out把值賦給變數

他兩的區別:TryParse轉換失敗不會引發異常,只會返回false;被轉換的值是null,或者格式不對、溢位等等情況,

如果是數值型別out出來的值是0,如果是字元型別則是未定義的值,布林的是false,....

string str1 = "abc",str2 = "123"; int a, b; arse(str1,out a); arse(str2,out b); eLine(a); eLine(b);

輸出結果: 0

123

值型別 =》string:

最後就是tostring()方法,任何資料型別你都可以toString一下,而且toString()可以自己定義轉換方法,tostring()是平時用的最多的了,這個就不多說了.

ps:寫的很亂,想到什麼寫什麼,就當“散文”看吧