Java 是当今最常用的编程语言之一,因为它包含高级特性和功能。在 Java 的每个新版本中,其开发人员都会添加新的特性和功能,而整数缓存是 Java 5 中引入的一项功能。在本教程中,我们将了解 Java 中的整数缓存是什么以及它在编程中的重要性。 p>
Java 中的整数缓存是什么?
从“缓存”一词,读者可以猜测我们正在讨论将整数存储在内存中并在需要时重新使用它。是的,你猜对了。但我想到的问题是为什么我们需要整数缓存。
让我们通过示例代码了解整数缓存的工作原理以及为什么我们在 Java 中需要它。
示例
在下面的示例中,我们定义了第一个和第二个整型变量,并将它们初始化为 100,范围为 -128 到 127。之后,我们比较这两个变量,并根据比较结果。
此外,我们还定义了第三个和第四个整型变量,并用 130 个不在 -128 到 127 范围内的值初始化它们。此外,我们还比较了它们并在输出中显示了结果值。
import java.io.*;
public class Main {
public static void main(String[] args) {
Integer first = 100;
Integer second = 100;
// It prints true only when both objects have the same reference
if (first == second) {
System.out.println("true");
} else {
System.out.println("false");
}
Integer third = 130;
Integer fourth = 130;
if (third == fourth) {
System.out.println("true");
} else {
System.out.println("false");
}
}
}
登录后复制
输出
true
false
登录后复制
如果我们猜测输出,两者都应该返回“false”输出,因为“==”运算符用于匹配对象的引用。仅当两个对象具有相同的引用时,“==”运算符才返回 true。但是,如果我们需要在Java中比较对象值,我们可以使用equals()方法,但不能使用'=='运算符来匹配对象值。
因此,澄清了当两个对象具有相同引用时“==”返回 true,并且对于“第一个”和“第二个”对象的比较返回 true。这意味着“第一个”和“第二个”对象具有相同的引用。
所以,问题是 'first'、'second'、'third' 和 'fourth' 都是整数对象,但它仅在 'first' 和 'second' 的比较时返回 true,但对于“第三”和“第四”的比较。
这里引入了整数缓存的概念。
-128 到 127(含)是最常用的整数值。因此,当程序员创建一个值在-128到127范围内的新整数对象时,JVM首先检查内存中是否存在具有相同值的对象。如果是,则返回同一对象的引用。否则,它创建新对象并返回该对象的引用。
现在,程序员很清楚为什么由于缓存而比较“第一个”和“第二个”对象会返回 true。
但是,如果我们使用“new”关键字创建对象,它总是在内存中创建一个新对象。因此,整数缓存在这种情况下不起作用。
Integer first = new Integer(13);
Integer second = new Integer(13);
登录后复制
在上面的代码中,对象的值在-128到127之间。但是,当我们使用构造函数创建对象时比较两个对象时,它会返回 false。
整数缓存的好处
-
内存优化 - 如果对象存在,整数缓存将使用相同的对象存储 -128 到 127 之间的整数,而不是创建一个新对象。它节省了设备的内存。
-
性能 - 对象创建需要内存分配和对象初始化。因此,使用现有对象创建可以提高应用程序的性能。
结论
简单来说,整数缓存特性就是将最常用的整数对象缓存在内存中以供复用。它通过使用现有对象提高了应用程序的内存优化和性能。
以上就是Java中的Integer缓存的详细内容,更多请关注每日运维网(www.mryunwei.com)其它相关文章!