作为一个初学者,最近阅读了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中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号