Integer的比较判断

Integer的比较判断

先看下面代码

public class method1 {
    public static void main(String[] args) {
        Integer a=new Integer(1);
        Integer b=new Integer(1);
        System.out.println(a==b);
        Integer a1=1;
        Integer b1=1;
        System.out.println(a1==b1);
        Integer a2=128;
        Integer b2=128;
        System.out.println(a2==b2);
    }
}

结果为 :false ,true,false
分析

  • 第一个比较,因为new了两个对象,所以a,b分别指向了不同的对象,所以地址不相同,所以是false
  • 第二个和第三个,好像都一样,但结果却不一样,此时就要看源码了,当用debug的时候,发现,走到了Integer的valueOf方法,发现当在low 和 high之间就会返回一个值,当不在范围时,就会new一个新对象;而这个范围是-128到127之间,所以第二个判断为真,第三个为假
public static Integer valueOf(int i) {
        if (i >= IntegerCache.low && i <= IntegerCache.high)
            return IntegerCache.cache[i + (-IntegerCache.low)];
        return new Integer(i);
    }

接下来再看

		Integer e=127;
        int f=127;
        System.out.println(e==f);
        Integer c=128;
        int d=128;
        System.out.println(c==d);

结果都为真;
只要有基本数据类型,都为比较值,所以都为真

在 MyBatis 的 XML 映射文件中,`<if test="">` 标签用于根据传入的参数值动态生成 SQL 语句。当需要对 `Integer` 类型的数值进行判断时,需要注意以下几点: 1. **避免使用字符串比较操作符** 对于非字符串类型的参数(如 `Integer` 或 `Long`),不能使用 `!= ''` 或 `== ''` 这样的表达式进行判断,因为这些类型本身不包含空字符串的概念。例如,若传入的参数是 `Integer` 类型,则 `<if test="age != null and age != ''">` 会导致错误,因为空字符串无法与整数进行比较 [^3]。 2. **正确使用 null 判断** 如果需要判断某个 `Integer` 类型参数是否为 `null`,可以使用 `!= null` 来确保参数存在后再进行其他逻辑处理。例如: ```xml <if test="age != null"> AND age = #{age} </if> ``` 3. **直接进行数值比较** 若需要对 `Integer` 类型参数进行具体的数值比较,可以直接使用 `>`、`<`、`==` 等操作符。例如: ```xml <if test="age > 18"> AND age > 18 </if> ``` 4. **结合逻辑运算符进行复杂条件判断** 可以通过 `and` 和 `or` 搭配多个条件,实现更复杂的查询逻辑。例如: ```xml <if test="age != null and age > 20 and age < 30"> AND age BETWEEN 21 AND 29 </if> ``` 5. **避免潜在的类型转换问题** 在某些情况下,MyBatis 内部可能会尝试将不同类型进行隐式转换,但这种行为可能引发不可预期的结果。例如,表达式 `0 == ''` 在某些解析器内部会被认为是 `true`,这是由于空字符串被转换为 `0` 所致。因此,在编写 `test` 表达式时应尽量避免混合不同数据类型的比较 [^3]。 6. **使用 CDATA 区块避免 XML 转义问题** 当表达式中包含特殊字符(如 `<`、`>`)时,建议使用 `<![CDATA[]]>` 区块来包裹内容,以防止 XML 解析错误。例如: ```xml <if test="age != null"> AND age <![CDATA[ >= ]]> 18 </if> ``` ### 示例代码 ```xml <select id="selectUsersByAge" resultType="User"> SELECT * FROM users <where> <if test="age != null"> AND age = #{age} </if> <if test="minAge != null and maxAge != null"> AND age BETWEEN #{minAge} AND #{maxAge} </if> </where> </select> ``` ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值