首頁  >  文章  >  JDK 1.8原始碼中,為什麼要用A-B>0來判斷哪一個比較大,而不是A>B呢?

JDK 1.8原始碼中,為什麼要用A-B>0來判斷哪一個比較大,而不是A>B呢?

WBOY
WBOY轉載
2024-02-06 11:36:031122瀏覽
問題內容

作為一個初學者,最近閱讀了jdk1.8的原始碼。我遇到的問題是為什麼使用 a-b> 0 來確定哪個更大,而不是 a> b?

下面的程式碼在java/util/arraylist.java:236中

private void ensureExplicitCapacity(int minCapacity) {
    modCount++;

    // overflow-conscious code
    if (minCapacity - elementData.length > 0)
        grow(minCapacity);
}

我無法理解 mincapacity - elementdata.length > 0 的程式碼。為什麼不使用 mincapacity > elementdata.length。


正確答案


可能是為了防止 mincapacity 溢出,請檢查以下範例:

public static void main(String[] args) {
    int elementDataLength = 10;
    int minCapacity = Integer.MAX_VALUE; // very big

    minCapacity += 1; // accidentally overflow it

    if (minCapacity > elementDataLength) {
        System.out.println("Will not work: minCapacity=-2147483647 elementDataLength=10");
    }
    if (minCapacity - elementDataLength > 0) {
        System.out.println("Will work: minCapacity - elementDataLength = 2147483638");
    }
}

以上是JDK 1.8原始碼中,為什麼要用A-B>0來判斷哪一個比較大,而不是A>B呢?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:stackoverflow.com。如有侵權,請聯絡admin@php.cn刪除