首页 > Java > JDK 1.8源码中,为什么用A-B>0来判断哪一个更大,而不是A>B呢?

JDK 1.8源码中,为什么用A-B>0来判断哪一个更大,而不是A>B呢?

WBOY
发布: 2024-02-06 11:36:03
转载
1156 人浏览过
问题内容

作为一个初学者,最近阅读了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
最新问题
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板