for 循环使用不当导致死循环,CPU激增
2018-01-03 19:42
363 查看
CPU激增
最近发现生产上的某些台服务区CPU激增,跟着内存也增长的比较厉害,就跟踪了下(CPU过高查询方法此处不再赘述,自行百度)发现线程卡在某一方法处,如下:代码
看了这个方法的代码,原来是一个for循环中的代码,就猜想可能是死循环了,如下:public static String getGMTNumOfYear(Date yyyyDateTime) throws ParseException { String gmtDate = getGMT(yyyyDateTime); SimpleDateFormat simpleDateFormat = new SimpleDateFormat( "yyyyMMddHHmmss"); Date date =simpleDateFormat.parse(gmtDate); Calendar cd = Calendar.getInstance(); cd.setTime(date); String yearOfNumber = cd.get(Calendar.DAY_OF_YEAR) + ""; if (yearOfNumber.length() < 3) { for (int i = 3 - yearOfNumber.length(); i > 0; i++) { yearOfNumber = "0" + yearOfNumber; } } return yearOfNumber; }
这个方法的目的是为了获取某一天在该年中是第几天,如果不足三位(一年365天),则前补0然后返回出去.
原因
可是死循环不应该测不出来的啊,一个功能的上线都是经过测试部测试的。后来分析了下,果然找到了原因,查看代码提交日期,是下半年开发的代码,也就是说当时测试的时候不管怎么测试,返回的yearOfNumber都是三位,经过for循环的初始化int i = 3 - yearOfNumber.length(),i为0就不会执行这个for循环,所以当时就没测出来这个问题。
然而刚过元旦,今天是1月3号,华丽丽的执行了这个for循环,当时代码开发者也是想当然了,觉得for循环的初始化会一直执行,熟不知,只会执行一次,最终的结果就导致了i一直增加,for循环的条件i > 0就一直成立,最终导致死循环。
相关文章推荐
- 线程中直接使用死循环,不会导致cpu将达到 100%
- 不正当使用HashMap导致cpu 100%的问题追究(HashMap死循环探究)
- 1118 while循环比for更容易导致死循环
- map使用不当导致cpu暴涨
- for循环语句嵌套使用的实例
- 对于集合的遍历操作,可以使用 itrator foreach for 循环,下面比较一下各自的优缺点
- 如何在游标for循环中使用动态SQL语句?
- 练习2-2 在不使用运算符&&或者||的条件下编写一个与上面的for循环语句等价的循环语句。
- SHELL 循环获取日期以及FOR使用
- 实现1+2+3...+n,要求不能使用乘除法、循环、条件判断、选择相关的关键字(for、while、if、else、switch、case)。
- Swift学习——使用if和switch来进行条件操作,使用for,while,和do-while来进行循环(三)
- 【IDE-Visual Studio】visual Studio(vs)经常在操作,测试中运行中未响应,cpu使用达到100%,导致其他软件、浏览器等卡死
- odbcasvc.exe导致CPU使用100%问题的解决办法
- 循环语句for的使用方法
- 【解决方案】闭包函数在for循环中的使用案例——for循环绑定监听事件索引值总是最后一个
- 预习 for 循环的使用和数组的概念
- 不正当使用HashMap导致cpu 100%的问题追究
- strlen放置在for循环条件判断中容易导致死循环
- Python的for和break循环结构中使用else语句的技巧
- 练习2-2 在不使用运算符&&或|| 的条件下编写一个与上面的for循环语句等价的循环语句