进击的小白——知识点:查找程序bug原因及位置(以遗传算法程序为例)

程序查错方法:

  1. 小范围查错,单步调试,用Watch窗口查看各个变量的值;
  2. 大范围查错,用printf输出每个模块返回的结果,通过结果查错。

之前写的遗传算法程序出现了一个问题:没报错,没中断,但循环会在某一次卡住,且卡住的次数随机。

排障思路:

  1. 把每个模块都加上printf,观察程序停止的地方,可以看到,程序每次都停在cross1和cross2中间,因此有可能是cross(交叉)这个部分出了问题
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
  2. 在cross的开头和末尾设置两个或多个断点,单步调试,查找具体错误位置,最终发现是程序陷入死循环,原因是种群个体基因值出现负值,不满足循环跳出条件,因此陷入死循环
  3. 查找基因值为负的原因,可能导致因为为负的原因有两个地方:①cross(交叉)、②vary(变异),下面继续通过printf打印cross和vary的各个个体基因的值,发现每次首次出现负值,都在vary中,因此断定程序bug的原因在vary中。

结论:
程序没有按照设定的循环次数进行,而是在中间某一次停止,没有报错也没有强制中断,可能的原因是陷入死循环,优先查找程序中可能陷入死循环的部分。

猜你喜欢

转载自blog.csdn.net/u011232393/article/details/86640166
今日推荐