Rumah  >  Artikel  >  Dalam kod sumber JDK 1.8, mengapakah A-B>0 digunakan untuk menentukan yang mana satu lebih besar dan bukannya A>B?

Dalam kod sumber JDK 1.8, mengapakah A-B>0 digunakan untuk menentukan yang mana satu lebih besar dan bukannya A>B?

WBOY
WBOYke hadapan
2024-02-06 11:36:031125semak imbas
Kandungan soalan

Sebagai seorang pemula, saya baru-baru ini membaca kod sumber jdk1.8. Soalan yang saya ada ialah mengapa menggunakan a-b>

Kod berikut ada dalam java/util/arraylist.java:236

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

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

Saya tidak faham kod mincapacity - elementdata.length > 0. Mengapa tidak menggunakan mincapacity > elementdata.length.


Jawapan betul


Mungkin untuk mengelakkan kekurangan kapasiti limpahan, sila semak contoh berikut:

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

Atas ialah kandungan terperinci Dalam kod sumber JDK 1.8, mengapakah A-B>0 digunakan untuk menentukan yang mana satu lebih besar dan bukannya A>B?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:stackoverflow.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam