java boolean is_使用java Bean时,is打头的boolean属性的小坑

申明属性,然后用idea自带的Generator生成getter,setter(封装类型和基本数据类型生成的还不一样),如下:

ae5a9dd9b857c7e29f516cdb778947eb.png

当我去构造一个PropertyDescriptor时,会报错

283d6e5267af1ed816fc240ef52d97f8.png

0ebee092a9cb8d31aebb1e5e4608dce7.png

后来跟代码,发现,报错原因是PropertyDescriptor的构造函数去找一个叫setIsSuccess的写值函数时,发现找不到,于是报错了。

e2495486f11982350051b00317f8d854.png

f328fceedd69bdaa197458084dd79437.png

从上图可以看到,实际在构造PropertyDescriptor时,它会尝试去寻找一个叫isIsSuccess的读函数,一个叫setIsSuccess的写函数。当isIsSuccess没找到时,它会尝试去找叫getIsSuccess的读函数,如果还是没找到,则抛出异常。当setIsSuccess没找到时,也会抛出异常。

试了一下发现,用idea自动生成getter,setter只有在使用is打头的boolean时有这个问题(封装类型和基本数据类型都有问题),其他数据类型没有这个问题。

aa0ca300dc445e232e3d97baed3a124f.png

这方面的问题有时还涉及到json转换,所以在处理布尔类型数据时,又用is打头来命名时,不要使用idea自动生成getter和setter。另外,行业里好像比较合理的做法是禁止Bean里用is打头申明boolean类型的变量。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 MyBatis 中,当使用 `select` 语句查询结果为 `Boolean` 类型,会出现以下两种情况: 1. 查询结果为 0 或者为 null ,返回的是 `false`; 2. 查询结果不为 0 且不为 null ,返回的是 `true`。 如果你需要自定义返回结果的逻辑,可以通过实现 `org.apache.ibatis.type.TypeHandler` 接口来完成。下面是一个示例代码: ```java import org.apache.ibatis.type.BaseTypeHandler; import org.apache.ibatis.type.JdbcType; import java.sql.CallableStatement; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; public class BooleanTypeHandler extends BaseTypeHandler<Boolean> { @Override public void setNonNullParameter(PreparedStatement ps, int i, Boolean parameter, JdbcType jdbcType) throws SQLException { ps.setInt(i, parameter ? 1 : 0); } @Override public Boolean getNullableResult(ResultSet rs, String columnName) throws SQLException { int result = rs.getInt(columnName); return result == 1; } @Override public Boolean getNullableResult(ResultSet rs, int columnIndex) throws SQLException { int result = rs.getInt(columnIndex); return result == 1; } @Override public Boolean getNullableResult(CallableStatement cs, int columnIndex) throws SQLException { int result = cs.getInt(columnIndex); return result == 1; } } ``` 在 `setNonNullParameter` 方法中,将 Java 类型的 `Boolean` 转换成数据库类型的 `int`,并设置到 `PreparedStatement` 对象中。 在 `getNullableResult` 方法中,从 `ResultSet` 或者 `CallableStatement` 对象中获取 `int` 类型的结果,并将其转换成 `Boolean` 类型。如果结果为 1,则返回 `true`,否则返回 `false`。 最后,将该类型处理器注册到 MyBatis 的配置文件中即可: ```xml <typeHandlers> <typeHandler javaType="java.lang.Boolean" handler="com.example.BooleanTypeHandler"/> </typeHandlers> ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值