眾所周知java中的數(shù)據(jù)類型是強數(shù)據(jù)類型,基本數(shù)據(jù)類型之間的轉換尤其固定的規(guī)則,當數(shù)據(jù)寬度比較窄的數(shù)據(jù)類型(如int)轉換成數(shù)據(jù)類型比較寬的數(shù)據(jù)類型時(如double),則窄的數(shù)據(jù)類型會加寬,可以完成自動類型轉換,這稱為隱式轉換。
如:以下代碼沒有任何問題,結果也是正確的,成績不會發(fā)生變化,所不同的是成績的精度提高了。
1
2
|
intintscore = 96 ; doubledoublescore = intscore; |
那么如果試圖把寬的數(shù)據(jù)類型(如double)轉換成窄的數(shù)據(jù)類型(如float)時,編譯器會提示編譯錯誤,想要編譯通過,需要進行強制類型轉換。那么,此時的數(shù)據(jù)會發(fā)生截斷。產(chǎn)生的結果是:
1. 數(shù)據(jù)正確,只是精度降低了;
2. 數(shù)據(jù)不正確,發(fā)生了溢出;
對于上述第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類型的數(shù)據(jù)強制轉換成float類型,發(fā)生了截斷。雖然數(shù)據(jù)的大小沒有變化,但是數(shù)據(jù)的精度卻降低了。
同理:
1
2
|
doubleweight = floatweight; //隱式轉換 floatweight = ( float )doubleweight; //強制轉換 |
現(xiàn)在,問題來了,既然是截斷,怎么會產(chǎn)生溢出呢?我們先來看個例子:
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呢?這是因為強制轉換時發(fā)生溢出。由于150超出了byte能夠表示的最大范圍(-128 ~ 127)。
那么-106又是如何得來的呢?
i = 150,用二進制表示i = 0000 0000 1001 0110,short類型占2個字節(jié),16位,最高位的0表示正數(shù)。當把i強制轉換成byte類型時,高位發(fā)生截斷,i = 1001 0110。在計算機中,用補碼表示,最高位的1表示負數(shù),那么用原碼表示的話:i = 1110 1010,正好表示十進制數(shù)-106。
至此,也就解釋了為什么截斷也可能會發(fā)生溢出。
以上所述是小編給大家介紹的java中的類型轉換問題詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對服務器之家網(wǎng)站的支持!
原文鏈接:https://blog.51cto.com/weiweili/1901017