简单地说:有没有人知道gdb的GUI可以与最新版本的Visual c++中的特性集相提并论或接近?
详细说明:作为一个在Windows上花了大量时间编程的人,每当我必须在Linux中编写c++代码时,我发现的一个较大的绊脚石是,使用命令行gdb调试任何东西所花费的时间比在Visual Studio中长几倍,而且随着练习,它似乎并没有变得更好。有些东西用图形表示更容易或更快。
具体地说,我正在寻找一个GUI:
Handles all the basics like stepping over & into code, watch variables and breakpoints
Understands and can display the contents of complex & nested C++ data types
Doesn't get confused by and preferably can intelligently step through templated code and data structures while displaying relevant information such as the parameter types
Can handle threaded applications and switch between different threads to step through or view the state of
Can handle attaching to an already-started process or reading a core dump, in addition to starting the program up in gdb
如果这样的程序不存在,那么我希望听到人们使用至少满足其中一些要点的程序的经验。
有人有什么建议吗?
编辑:
列出这些可能性很好,我也会尽我所能,但如果你能在回答中包括以下内容,那就更有帮助了:
(a)你是否实际使用过这个图形用户界面,如果使用过,你对它有什么积极/消极的反馈。
(b)如果你知道,上述哪些功能是受支持的或不受支持的
列表很容易获得,像这样的网站很棒,因为你可以了解人们使用应用程序的个人体验。
Eclipse CDT将提供与使用Visual Studio相当的体验。我每天都使用Eclipse CDT来编写代码和调试本地和远程进程。
如果您不熟悉使用基于Eclipse的IDE,那么GUI将需要一点时间来适应。然而,一旦您理解了Eclipse特有的GUI思想(例如透视图),使用该工具就会成为一种很好的体验。
CDT工具提供了一个不错的C/ c++索引器,允许您快速查找代码库中方法的引用。它还提供了一个很好的宏扩展工具和有限的重构支持。
关于对调试的支持,CDT能够做列表中的所有事情,除了读取核心转储(它可能支持这个功能,但我从未尝试使用过这个功能)。而且,我使用模板调试代码的经验有限,所以我不确定CDT在这方面能提供什么样的经验。
有关使用Eclipse CDT进行调试的更多信息,您可能需要查看以下指南:
与CDT调试器的接口,第2部分:使用Eclipse CDT和MI访问gdb
CDT调试教程
我讨厌Windows开发的想法,但vc++调试器是我见过的最好的调试器之一。我还没有找到一个GUI前端接近VC的。
一旦您真正习惯了GDB,它就非常棒。在生气的时候经常使用它,你会变得非常熟练。我可以轻松地在程序中完成您列出的所有事情。我确实花了一个月左右的时间才熟练地连接到远程服务器。但我永远不会回去。
DDD功能非常强大,但也有很多bug。我发现当它收到来自GDB的消息说它不懂时,它经常会死机。它很好,因为它有一个gdb接口窗口,所以你可以看到正在发生什么,也可以直接与gdb交互。在我的环境中,DDD不能在远程X会话上使用(这是一个真正的问题,因为当我做Unix开发时,我坐在瘦客户机上),因此出于某种原因,它对我来说是不合适的。
KDevelop遵循典型的KDE风格,向用户公开一切。在KDevelop中调试非KDevelop程序时,我也没有任何运气。
Gnat Programming Studio (GPS)实际上是一个非常好的GDB前端。它不只是管理Ada项目,所以如果你需要调试器,它值得一试。
你可以使用Eclipse,但它的重量相当大,我所共事过的许多经验丰富的Unix人员(包括我在内)都不太关心它的界面,它不会只是STFU,也不会给你带来麻烦。Eclipse似乎也占用了很多空间,运行起来像狗一样。
In the last 15 months I use insight (came with FC6). It is not great, it is written in Tcl/Tk, but it is simple and useful. DDD is of similar quality / utility, but somewhat harder to use (various GUI gotchas and omissions). I also tried to integrate gdb with my IDE, SlickEdit. It worked OK (I played some 4 hours with it), but I did not like the GUI context switches. I like my IDE to remain unchanged while I am debugging; on Windows I use SlickEdit for IDE and Visual Studio Debugger for debugging. So from the 3: Insight, DDD and SlickEdit, Insight is my 1st choice, I use it >95% of the time, command-line gdb and DDD make up the other 5%. If I get the chance, I will eval Eclipse at some point, my work PC does not seem to have enough RAM (1GB only) to run Eclipse reasonably well.
我也听到了很多对TotalView的赞美,包括在一次工作面试中。我在2008年底获得了对我们公司的评估,但最终我们没有继续进行,因为gdb足够满足我们的需求;而且它是免费的,无处不在。
Qt Creator似乎是个好东西。一位同事向我展示了一种调试的方法:
Create a new project, "Import of Makefile-based Project".
Point it to your root project folder (it will index sources under it, and it is impressively fast).
Go to project settings and add a run configuration, then specify the executable you want to debug, and its arguments.
Qt Creator seems to insist on building your project before debugging it. If you don't want that, or don't use make, just go to projects -> build (Left panel), then, on the right panel in "Build Steps", remove all the steps, including the step by default when you created the project.
对于调试一个我已经编译好的应用程序来说,这似乎有点多,但这是值得的。调试器以类似于Visual Studio的方式显示线程、堆栈和局部变量,甚至使用许多相同的键盘快捷键。它似乎可以很好地处理模板,至少std::string和std::map。附加到现有进程和核心转储似乎是受支持的,尽管我还没有测试它。
请记住,我现在使用它不到一个小时,但迄今为止我印象深刻。
我正在寻找一个调试器来逐步调试正在运行的程序。说:附加。该程序是用eclipse构建的,但由于可能存在一些多线程障碍,没有源文件。过什么。
我用NetBeans很舒服。
[debug] from menu ->附加调试器…
当进程选择要调试的程序时
As project[新项目]
现在窗户消失了,你什么也看不见。脱离这个过程。Read方形的“Stop”会有所帮助。
从项目中导入源代码,例如文件夹。“……/ MyProject / src
现在它出现在您的项目中,您可以设置断点。
同样是ttach调试器
选择要调试的流程。
如果程序到达下一个断点,调试器应该停止。
打开[window] -> [Debugging] ->您的窗口是否使您感到舒适。