找不好重现的bug的一个小技巧————守株待兔

最近碰到一个问题就是数据库中偶尔出现一条没有id的数据,可恨的是怎么也找不到重现这个问题的原因,只好换种方式来找了,那么就是我标题所说的守株待兔方法。

因为我发现出现bug的数据库里面的数据有个字段为msg_contend的内容有个共性就是以“.png.down”结尾,并且这个内容来源的功能模块也能确定为FileTransServer。另外可以知道保存数据到数据库的方法只有一个save_a_message_item(),那么我就在这个门口设置个过滤器 “#ifdef _DEBUG... #endif // _DEBUG”,如果保存数据到数据库的时候内容包含“.png.down”,那么我就断点在这里,这样根据堆栈信息就可以轻易知道问题所在了。

对于找不到重新bug的问题,这个方法不错吧。

原文地址:https://www.cnblogs.com/superstargg/p/4061862.html