你知道 Boolean#getBoolean(String) 干了什么吗?

事情是这样的,周末晚上群里有人说后台菜单刷不出来了,刷了几次就好了。

今早到公司,查看服务器日志,定位到如下异常:
在这里插入图片描述
这个问题是使用的connection空闲时间超过了MySQL的wait_timeout,该连接被断开。数据库连接池这里使用的是Druid,查看配置项没问题:
在这里插入图片描述

接下来查看DataSource的初始化:

DruidDataSource dds = new DruidDataSource();
...
dds.setTestWhileIdle(Boolean.getBoolean(this.props.getProperty("testWhileIdle")));

看起来似乎没有问题,打个断点查看DataSource初始化完的属性:
在这里插入图片描述

明明设置了testWhileIdle=true,这里为什么是false呢。

打个断点查看一下发现如下,果然testWhileIdle被设置成了false
在这里插入图片描述

直觉告诉我这个Boolean#getBoolean(String)可能有问题,继续深入方法,当看到这个就知道问题出现在哪了。

Boolean#getBoolean(String)并不是将字符串转换为boolean值,而是从System properties中查询该key,将查询到的value转换为boolean值。

在这里插入图片描述

Boolean#parseBoolean(String)或者Boolean#valueOf(String)才是“想”使用的方法,世界和平。

在这里插入图片描述

写这个代码的同学已经拖出去揍了?,但是没揍他之前我也不知道这个坑?

看起来没问题,也就是看起来而已。。。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值