当您将通用类型与实用程序类一起使用时,您经常会发现数字类型在指定为对象类型时不是很有用,因为它们不等于原始类型。
List<Integer> ints = new ArrayList<Integer>();
List<Integer> ints = new ArrayList<>();
幸运的是,int可以在需要时使用评估为的表达式Integer。
for (int i = 0; i < 10; i++) ints.add(i);
该语句等效于:ints.add(i);
ints.add(Integer.valueOf(i));
并保留属性,Integer#valueOf例如Integer在数字高速缓存范围内时,由JVM高速缓存相同的对象。
这也适用于:
byte 和 Byte
short 和 Short
float 和 Float
double 和 Double
long 和 Long
char 和 Character
boolean 和 Boolean
但是,在模棱两可的情况下必须小心。考虑以下代码:
List<Integer> ints = new ArrayList<Integer>(); ints.add(1); ints.add(2); ints.add(3); ints.remove(1); // 现在的整数是[1,3]
所述java.util.List接口包含一个remove(int index)(List界面法), remove(Object o)(从继承的方法java.util.Collection)。在这种情况下,不会进行拳击remove(int index)。
造成由自动装箱与范围内的值的整数奇怪的Java代码的行为再举一个例子-128来127:
Integer a = 127; Integer b = 127; Integer c = 128; Integer d = 128; System.out.println(a == b); // 真正 System.out.println(c <= d); // 真正 System.out.println(c >= d); // 真正 System.out.println(c == d); // 假
发生这种情况是因为>=运算符在比较引用而不是值时隐式调用intValue()返回的值。int==int
默认情况下,Java将值缓存在range中[-128, 127],因此运算符==可以工作,因为Integers如果范围相同,则此范围内的引用相同的对象。可以使用-XX:AutoBoxCacheMaxJVM选项定义可缓存范围的最大值。因此,如果使用运行程序-XX:AutoBoxCacheMax=1000,将显示以下代码true:
Integer a = 1000; Integer b = 1000; System.out.println(a == b); // 真正