Ecplise常见问题-对策 收藏
最近,一直在做一个打印机的项目,在使用微软的测试数据的时候,遇到了一些 BUG ,接下来理所当然就是 BUG 对应、 DEBUG 了,因为这个模块是我从别人手里接过来的, DEBUG 的时候,也遇到了一些问题。
在使用 Ecplise 进行 DEBUG 的时候,往往要监视一些重要变量的变化情况,像普通的 int,bool , char*,class 的对象,直接使用“ Variables ”窗口,就可以直接的监视变量的变化情况,而对于一些比较复杂的数据结构,有的时候,可能只需要监视她的某个成员的变化。这时,我就想到使用另外一个窗口“ Expressions” 的 watch 功能来取得一些数据,
比如添加 current_path->getString() 来取得内部保存的字符串。
这个机能使用起来,确实非常的方便。
但是,经过一段时间的使用,发现了一些平时不会出现的问题。
比如,当在打开窗口 “ Expressions” ,平且,使用了一些变量的 watch 以后,在调试的时候,会遇到如下一些情况,
下面是在 DEBUG 时,窗口“ console ”中输出的几种错误信息
=========================================================
mi_cmd_var_create: unable to create variable object
mi_cmd_var_create: unable to create variable object
=========================================================
Single stepping until exit from function ntdll!LdrDisableThreadCalloutsForDll,
which has no line number information.
=========================================================
No symbol "current_path" in current context.
No symbol "current_path" in current context.
No symbol "current_path" in current context.
=========================================================
No source available for "ntdll!LdrDisableThreadCalloutsForDll() "
=========================================================
Variable object not found
Variable object not found
下面是错误提示窗口的,提示信息
=========================================================
Error: Target request failed:{R,T}xThread terminated.
=========================================================
还有,
Debug 调试的时候, Eclipse 莫名奇妙的停止运行。
最后,经过代码的 review ,确认,结论是,在代码中并不存在问题。
问题的原因可能是 Ecplise 本身有问题,后来,经过多种尝试,
得出结论,
只有在需要的时候,在使用“ Expressions” 的 watch 功能,使用完后,立即清除所有的 watch ,
这样,就不会有任何的错误提示了。
解决这个问题,花费了我大约一整天的时间,有时,会让人觉得这个问题莫名奇妙,根本就没有头绪。
希望我的总结,能给需要的人带来帮助。