2022年第一个线上问题,被领导骂惨了!
Hollis
共 1781字,需浏览 4分钟
·
2022-01-14 02:16
昨天,一位朋友说他们生产环境出bug了,哎,年底了,今年的年终奖估计凉凉了!
这位朋友刚刚出道不久,出了问题,第一时间找的我。
他把出问题的代码发我了,叫我帮他review这段代码。
for (ProductOrderItem orderItem : orderItemList) {
if (orderItem.getProductOrderItem_user().getUser_id() != user.getUser_id()) {
logger.warn("用户订单项与用户不匹配,回到购物车页");
return "redirect:/cart";
}
if (orderItem.getProductOrderItem_order() != null) {
logger.warn("用户订单项不属于购物车,回到购物车页");
return "redirect:/cart";
}
}
看这段代码,不是很简单吗?
我只能盲猜了
是不是两个user_id不一样,数据有问题导致的? 你这user_id是Integer类型? 或者是 orderItem.getProductOrderItem_order()
不等null?
我让他debug看看,过一会,他说奇了怪了,并甩给我一个截图:
user_id
不相等的地方,我猜测IDEA
编辑器已经提示他了。两边都是Integer,属于int的包装类,也就是两个Integer对象,你用!=
去比较,这不是扯淡么?IDEA编辑器
会这么提示的:使用IDEA编辑器开发的朋友,田哥建议你多看看IDEA给你的代码提示
问题来源
在此,也希望大家养成一个良好习惯,不要再这么编码,对团队负责也是对自己负责!
!=
没有使用equals()导致的。故事还没结算
!=
,在本地测试和测试环境,也都没问题!最后,其实测试的小伙伴这会也要跟着背锅!
public class Test {
public static void main(String[] args) {
Integer aa=100;
Integer bb=100;
System.out.println(aa==bb);
Integer cc=128;
Integer dd=128;
System.out.println(cc==dd);
Integer ee=129;
Integer ff=129;
System.out.println(ee==ff);
}
}
-128~127
做了缓存。true
false
false
后记
吃一堑长一智!
有道无术,术可成;有术无道,止于术
欢迎大家关注Java之道公众号
好文章,我在看❤️
评论