Java转换难题者,不适合工作(或面试)
一個非常艱苦的面試問題可能是這樣的:
為什么打印出正確的文字?
乍一看,答案似乎很明顯,直到您意識到如果長時間更改int,事情都會變得很奇怪:
long i = Integer.MAX_VALUE; i += 0.0f; int j = (int) i; System.out.println(j == Integer.MAX_VALUE); // false System.out.println(j == Integer.MIN_VALUE); // true您可能會想什么呢? Java何時成為JavaScript?
首先,讓我解釋為什么長時間會產生如此奇怪的結果。
關于+ =的重要細節是它進行隱式強制轉換。 您可能會認為:
a += b;
是相同的:
a = a + b;
基本上,除了大部分時間無關緊要之外,還有一個細微的差別:
a = (typeOf(a)) (a + b);
加法的另一個微妙特征是結果是兩種類型的“范圍更大”。 這意味著:
i += 0.0f;
實際上是:
i = (long) ((float) i + 0.0f);
將Integer.MAX_VALUE轉換為浮點數時,會出現舍入錯誤(因為浮點數的尾數為24位),導致該值比開始時多一個。 即它與:
i = Integer.MAX_VALUE + 1; // for long i
當您再次將Integer.MAX_VALUE + 1轉換為int時,將發生溢出,并且具有:
Integer.MIN_VALUE;
j = Integer.MIN_VALUE;
那么,為什么長得到意外的值,而int恰好得到預期的值呢?
原因是當從浮點數舍入到整數時,它會舍入到0,直到最接近的可表示值。 從而:
int k = (int) Float.MAX_VALUE; // k = Integer.MAX_VALUE;
int x = (int) (Integer.MAX_VALUE + 1.0f) // x = Integer.MAX_VALUE;
注意:Float.MAX_VALUE / Integer.MAX_VALUE是1.5845632E29,這真是一個錯誤,但最好的int可以做到。
簡而言之,對于int值Integer.MAX_VALUE,語句i + = 0.0f; 導致該值先跳一(強制轉換為浮點數),然后再跳一(強制轉換為int值),以便您獲得開始時的值。
翻譯自: https://www.javacodegeeks.com/2014/10/a-java-conversion-puzzler-not-suitable-for-work-or-interviews.html
總結
以上是生活随笔為你收集整理的Java转换难题者,不适合工作(或面试)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 化妆品备案员的职业发展看待(化妆品备案员
- 下一篇: 在github上托管Maven存储库(包