Heim  >  Artikel  >  Warum wird im JDK 1.8-Quellcode A-B>0 anstelle von A>B verwendet, um zu bestimmen, welches größer ist?

Warum wird im JDK 1.8-Quellcode A-B>0 anstelle von A>B verwendet, um zu bestimmen, welches größer ist?

WBOY
WBOYnach vorne
2024-02-06 11:36:031085Durchsuche
Frageninhalt

Als Anfänger habe ich kürzlich den Quellcode von jdk1.8 gelesen. Die Frage, die ich habe, ist, warum a-b> verwendet wird, um zu bestimmen, was größer ist, und nicht a>

Der folgende Code befindet sich in java/util/arraylist.java:236

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

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

Ich kann den Code von mincapacity - elementdata.length > 0 nicht verstehen. Warum nicht mincapacity > verwenden?


Richtige Antwort


Wahrscheinlich um einen Kapazitätsmangel Überlauf zu verhindern, überprüfen Sie bitte das folgende Beispiel:

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");
    }
}

Das obige ist der detaillierte Inhalt vonWarum wird im JDK 1.8-Quellcode A-B>0 anstelle von A>B verwendet, um zu bestimmen, welches größer ist?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:stackoverflow.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen