首页 > 其他 > 详细

一次隐蔽的while死循环

时间:2019-04-06 18:20:46      阅读:183      评论:0      收藏:0      [点我收藏+]

技术分享图片

	private int  isStocksEnough(int goodsNum,int goodsID) {
		while(true) {
			sql = "select * from tb_goodsmanage where goodsID = ?";
			conn = DBUtil.getconn();
//		getconn()属于静态方法,只加载一次,即只执行一次
			try {
				ps = conn.prepareStatement(sql);
				System.out.println(ps);
				ps.setInt(1, goodsID);
				rs = ps.executeQuery();
				System.out.println(rs);
				if(rs.next()) {
					int a = rs.getInt("goodsNum");
					if(goodsNum>a ) {
						System.out.println("商品库存不足,仅剩:"+rs.getInt("goodsNum"));
						System.out.println("请重新选择商品数量");
						goodsNum = input.nextInt();
						isStocksEnough(goodsNum,goodsID);
						break;
					}
//不加else时,当库存满足时,会跳出if(goodsNum>a)代码块不执行,会重复上边的预编译SQL和SQL相关操作,但由于这些操作控制台没有显示输出,所以不易发现该死循环!1
// 但是静态方法getcoonn();只加载执行一次。当第二次是回去方法区查看有就直接调用。
//					else{
//						return goodsNum;
//					}
				}
			} catch (SQLException e) {
				e.printStackTrace();
				System.out.println("Error:系统错误");
			}
		}
		return goodsNum;
		}

  

 

一次隐蔽的while死循环

原文:https://www.cnblogs.com/klory/p/10662184.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!