Java Short类型比较的坑

Java Short类型比较的坑

前提约定:

精度小于int的数值==运算的时候(定义时不会)==都会被自动转换为int后进行计算


short x = 3;
Short s1 = 2;

if (s1.equals(x - 1)) {
  System.out.println("!!!!!");
}
// 输出:null
  • 其实,上述定义x,s1时,后面的3和2都是int型的,只是编译器在编译时帮我们自动转换为了对应的short类型。

  • 而在运算中编译器不会做上述转换,即: x - 1 变为了int 类型,而Short类型重写的equals方法如下:

    • !!!目标不是Short类型,直接会返回false
    public boolean equals(Object obj) {
        // !!!目标不是Short类型,直接会返回false
        if (obj instanceof Short) {
            return value == ((Short)obj).shortValue();
        }
        return false;
    }
    

    因此不会有任何输出。

  • 将if中的语句改为s1.equals((short)(x-1))即可

  • 因此,在map的使用时,应避免Short为key,若必须要用Short,则要注意这些,否则会出问题

    如HashMap中remove时对传入的key和map中的元素的对比:

    if (p.hash == hash &&
        ((k = p.key) == key || (key != null && key.equals(k))))// 其中key为外部传入的经过运算后的Short,为Integer,而k为Short
    

    此时,第2行的 == 判断直接false了,因为Short和Integer类型不能用==比较,而后面equals也为false,所以remove失效了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值