筆試面試 C型別轉換

2021-06-14 14:57:31 字數 2908 閱讀 9183

強制型別轉換是通過型別轉換運算來實現的。其一般形式為: (型別說明符) (表示式) 其功能是把表示式的運算結果強制轉換成型別說明符所表示的型別。例如: (float) a 把a轉換為實型(int)(x+y) 把x+y的結果轉換為整型在使用強制轉換時應注意以下問題:

1.型別說明符和表示式都必須加括號(單個變數可以不加括號),如把(int)(x+y)寫成(int)x+y則成了把x轉換成int型之後再與y相加了。

2.無論是強制轉換或是自動轉換,都只是為了本次運算的需要而對變數的資料長度進行的臨時性轉換,而不改變資料說明時對該變數定義的型別。

例1:main()

f<--5.75

將float f強制轉換成int f float f=5.75;printf("(int)f=%d,f=%f/n",(int)f,f); 本例表明,f雖強制轉為int型,但只在運算中起作用, 是臨時的,而f本身的型別並不改變。因此,(int)f的值為 5(刪去了小數)而f的值仍為5.75。

例2:比如我們可以(int)'a',這樣轉換後的結果為a的ascii碼數值,因為那塊記憶體本來就存的那個數,只是換個形式使用而已。 知道上面的原則,我們可以對任何資料型別進行轉換,但是轉換的結果可能不是你想像的結果,舉例(int)'9'的結果為多少?不是9而是0x39。來個高深點的printf("%d",'12');的輸出是什麼?正確答案是12849,因為printf("%d",'12'),列印的是儲存12的記憶體位址上的內容,即ascii碼值,12的低位數儲存在低位位址,即1儲存在低位,高位儲存在高位位址,0x32就是2的ascii碼,0x31就是1的ascii碼,所以是0x3231,轉換成10進製就是12849!

● 字元型變數的值實質上是乙個8位的整數值,因此取值範圍一般是-128~127,char型變數也可以加修飾符unsigned,則unsigned char 型變數的取值範圍是0~255(有些機器把char型當做unsighed char型對待, 取值範圍總是0~255)。

● 如果乙個運算子兩邊的運算數型別不同,先要將其轉換為相同的型別,即較低型別轉換為較高型別,然後再參加運算,轉換規則如下圖所示。

double ←── float 高

↑long

↑unsigned

↑int ←── char,short 低

● 圖中橫向箭頭表示必須的轉換,如兩個float型數參加運算,雖然它們型別相同,但仍要先轉成double型再進行運算,結果亦為double型。 縱向箭頭表示當運算子兩邊的運算數為不同型別時的轉換,如乙個long 型資料與乙個int型資料一起運算,需要先將int型資料轉換為long型, 然後兩者再進行運算,結果為long型。所有這些轉換都是由系統自動進行的, 使用時你只需從中了解結果的型別即可。這些轉換可以說是自動的,但然,c語言也提供了以顯式的形式強制轉換型別的機制。

● 當較低型別的資料轉換為較高型別時,一般只是形式上有所改變, 而不影響資料的實質內容, 而較高型別的資料轉換為較低型別時則可能有些資料丟失。

賦值中的型別轉換

當賦值運算子兩邊的運算物件型別不同時,將要發生型別轉換, 轉換的規則是:把賦值運算子右側表示式的型別轉換為左側變數的型別。具體的轉換如下:

(1) 浮點型與整型 

● 將浮點數(單雙精度)轉換為整數時,將捨棄浮點數的小數部分, 只保留整數部分。

將整型值賦給浮點型變數,數值不變,只將形式改為浮點形式, 即小數點後帶若干個0。注意:賦值時的型別轉換實際上是強制的。

(2) 單、雙精度浮點型 

● 由於c語言中的浮點值總是用雙精度表示的,所以float 型資料只是在尾部加0延長為doub1e型資料參加運算,然後直接賦值。doub1e型資料轉換為float型時,通過截尾數來實現,截斷前要進行四捨五入操作。 

(3) char型與int型 

● int型數值賦給char型變數時,只保留其最低8位,高位部分捨棄。 

● chr型數值賦給int型變數時, 一些編譯程式不管其值大小都作正數處理,而另一些編譯程式在轉換時,若char型資料值大於127,就作為負數處理。對於使用者來講,如果原來char型資料取正值,轉換後仍為正值;如果原來char型值可正可負,則轉換後也仍然保持原值, 只是資料的內部表示形式有所不同。 

(4) int型與1ong型 

● long型資料賦給int型變數時,將低16位值送給int型變數,而將高16 位截斷捨棄。(這裡假定int型佔兩個位元組)。 

將int型資料送給long型變數時,其外部值保持不變,而內部形式有所改變。 

(5) 無符號整數 

● 將乙個unsigned型資料賦給乙個佔據同樣長度儲存單元的整型變數時(如:unsigned→int、unsigned long→long,unsigned short→short) ,原值照賦,內部的儲存方式不變,但外部值卻可能改變。

● 將乙個非unsigned整型資料賦給長度相同的unsigned型變數時, 內部儲存形式不變,但外部表示時總是無符號的。 

/*例:賦值運算子舉例 */

main()

執行結果為:

(unsigned)65535→(int)-1

(int)-1→(unsigned)65535

● 計算機中資料用補碼表示,int型量最高位是符號位,為1時表示負值,為0時表示正值。如果乙個無符號數的值小於32768則最高位為0,賦給 int型變數後、得到正值。如果無符號數大於等於32768,則最高位為1, 賦給整型變數後就得到乙個負整數值。反之,當乙個負整數賦給unsigned 型變數時,得到的無符號值是乙個大於32768的值。 

● c語言這種賦值時的型別轉換形式可能會使人感到不精密和不嚴格,因為不管表示式的值怎樣,系統都自動將其轉為賦值運算子左部變數的型別。

● 而轉變後資料可能有所不同,在不加注意時就可能帶來錯誤。 這確實是個缺點,也遭到許多人們批評。但不應忘記的是:c面言最初是為了替代組合語言而設計的,所以型別變換比較隨意。當然, 用強制型別轉換是乙個好習慣,這樣,至少從程式上可以看出想幹什麼

mysql型別轉換c 型別轉換 C 型別轉換

一 簡介 型別轉換 把資料從一種型別轉換另一種型別 我們要求等號兩邊參與運算子必須型別一致,如果不一致,滿足下列條件會發生自動型別轉換或者隱式型別轉換。1.兩種型別相容 例如 int和double 相容 都是數字型別 2.目標型別大於源型別 double int 顯示型別轉換 1.兩種型別相相容 i...

c 筆試面試3

1 c stl 的實現 1.vector 底層資料結構為陣列 支援快速隨機訪問 2.list 底層資料結構為雙向鍊錶,支援快速增刪 3.deque 底層資料結構為乙個 控制器和多個緩衝區,詳細見stl原始碼剖析p146,支援首尾 中間不能 快速增刪,也支援隨機訪問 4.stack 底層一般用23實現...

C 型別轉換

在程式中,進行型別轉換是常見的事。那麼在 c 中支援以前語言的型別轉換方法,即用型別名進行強行轉換,例如 object objtest new newtype newtype newvalue newtype objtest 但是這樣轉換,有個嚴重的問題,就是在把 objtest 強轉換成 newt...