经典面试题集一

第一题:有关三元运算符的自动类型提升
Object o1=true?new Integer(1):new Double(2.0);
system.out.println(o1);
//结果为1.0
//自动类型提升为double类型
第二题:有关Integer类内部的IntegerCache结构
public void test()
{
Integer i=new Integer(10);
Integer j=new Integer(10);
system.out.println(ij);
//结果为false
//此时比较的是i与j的地址值
.
Integer m=1;
Integer n=1;
system.out.println(m
n);
//结果为true
.
Integer x=128;
Integer y=128;
system.out.println(x==y);
//结果为false
}
第二题总结:Integer类内部定义了IntegerCache结构,此结构定义了一个Integer[]数组,保存了-128~127的数。当我们自动装箱的方式,是直接使用数组中的元素,并没用new一个新的对象,因此比较的是这两个元素。但是一旦数子超过此范围(即128)则会重新new一个对象,因此第二题中x与y比较的是两个对象的地址值,因此为false。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值