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

这样,就不会有任何的错误提示了。

 

解决这个问题,花费了我大约一整天的时间,有时,会让人觉得这个问题莫名奇妙,根本就没有头绪。

希望我的总结,能给需要的人带来帮助。

 

 

你可能感兴趣的:(eclipse,数据结构,object,cmd,Path,variables)