眾所周知java中的數據類型是強數據類型,基本數據類型之間的轉換尤其固定的規則,當數據寬度比較窄的數據類型(如int)轉換成數據類型比較寬的數據類型時(如double),則窄的數據類型會加寬,可以完成自動類型轉換,這稱為隱式轉換。
如:以下代碼沒有任何問題,結果也是正確的,成績不會發生變化,所不同的是成績的精度提高了。
1
2
|
intintscore = 96 ; doubledoublescore = intscore; |
那么如果試圖把寬的數據類型(如double)轉換成窄的數據類型(如float)時,編譯器會提示編譯錯誤,想要編譯通過,需要進行強制類型轉換。那么,此時的數據會發生截斷。產生的結果是:
1. 數據正確,只是精度降低了;
2. 數據不正確,發生了溢出;
對于上述第1種情況,比較好理解,我們來看個例子:
1
2
|
float floatweight= 63.5 ; //編譯錯誤 double doubleweight= 63.5 ; |
上述第一條語句會提示編譯錯誤,那是因為編譯器看到63.5時,會把它當做一個double類型,把一個double類型賦給float類型,當然編譯不通過了。推薦的解決方案是:
1
|
float floatweight = 63 .5f; |
當然,你也可以強制轉換成float類型:
1
|
float floatweight = ( float ) 63.5 ; |
其實,上述語句本質是把double類型的數據強制轉換成float類型,發生了截斷。雖然數據的大小沒有變化,但是數據的精度卻降低了。
同理:
1
2
|
doubleweight = floatweight; //隱式轉換 floatweight = ( float )doubleweight; //強制轉換 |
現在,問題來了,既然是截斷,怎么會產生溢出呢?我們先來看個例子:
1
2
3
4
5
6
|
shorti = 150 ; shortj = 75 ; byteb = ( byte ) i; byted = ( byte ) j; system.out.println( "b = " + b); system.out.println( "d = " + d); |
以上代碼的輸出結果是:
b = -106
d = 75
看到結果,不免會問為什么b=-106呢?這是因為強制轉換時發生溢出。由于150超出了byte能夠表示的最大范圍(-128 ~ 127)。
那么-106又是如何得來的呢?
i = 150,用二進制表示i = 0000 0000 1001 0110,short類型占2個字節,16位,最高位的0表示正數。當把i強制轉換成byte類型時,高位發生截斷,i = 1001 0110。在計算機中,用補碼表示,最高位的1表示負數,那么用原碼表示的話:i = 1110 1010,正好表示十進制數-106。
至此,也就解釋了為什么截斷也可能會發生溢出。
以上所述是小編給大家介紹的java中的類型轉換問題詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對服務器之家網站的支持!
原文鏈接:https://blog.51cto.com/weiweili/1901017