项目场景:
提示:这里简述项目相关背景:
a bittler loser, 没有在问题上耗时
对了还有一个问题这里除了好像的问题那就是integer 的比较方式:
问题描述
提示:这里描述项目中遇到的问题:
我的方式是:是这种的方式是:结果报错了:
Integer a1 = new Integer(1);
System.out.println(a1.toString().equals("1")); //字符串的比较
System.out.println(a1.equals("1")); //inteer 的比较:
原因分析:
提示:这里填写问题的分析:
public boolean equals(Object obj) {
if (obj instanceof Integer) {
return value == ((Integer)obj).intValue();
}
return false;
}
可以看见是把对比的对象看是不是Integer类型的,是的话就转为int基本类型再用 == 比较,比较的就是数值了。所以来点特殊的。
源码的本质的比较的是看不能转换成int 类型否则是返回false.的。
但是
解决方案:
提示:这里填写该问题的具体解决方案:
查资料可以知道Integer有缓存数组,即-128<=value<=127,都从缓存数组中获取Integer对象。对于测试中的,q和w都是超过了缓存的值,因此都是new的新得对象,所以匹配不了。所以我们不难理解,Integer的“”方法是比较地址的。而Integer的equals方法则不会有这些问题,是直接字面上的比较。
因此使用Integer做比较的时候,的区分是否超过了缓存数组的区域。
大数字比较使用integer,小数据比较使用==.