简单地说:有没有人知道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调试教程

其他回答

KDevelop工作得很好。

我已经为gdb尝试了几个不同的gui,发现DDD是其中更好的一个。 虽然我不能评论linux上的其他非gdb产品,但我已经在其他平台上使用了许多其他调试器。

GDB可以完成您愿望清单中的大部分工作。DDD让他们看起来更漂亮。例如,线程切换变得更加简单。设置断点就像您期望的那样简单。

如果你想做一些模糊的事情,你也可以得到一个cli窗口。

DDD比我使用过的任何其他调试器都突出的一个特性是数据“绘图”。这允许你显示和安排结构,对象和内存作为拖拽框。双击一个指针将打开被解除引用的数据,并带有指向父节点的可视链接。

我正在寻找一个调试器来逐步调试正在运行的程序。说:附加。该程序是用eclipse构建的,但由于可能存在一些多线程障碍,没有源文件。过什么。

我用NetBeans很舒服。

[debug] from menu ->附加调试器… 当进程选择要调试的程序时 As project[新项目]

现在窗户消失了,你什么也看不见。脱离这个过程。Read方形的“Stop”会有所帮助。

从项目中导入源代码,例如文件夹。“……/ MyProject / src 现在它出现在您的项目中,您可以设置断点。 同样是ttach调试器 选择要调试的流程。 如果程序到达下一个断点,调试器应该停止。

打开[window] -> [Debugging] ->您的窗口是否使您感到舒适。

我经常使用DDD,一旦你学会使用它,它就非常强大。我想说的一件事是,不要在X上通过WAN使用它,因为它似乎做了很多不必要的屏幕更新。

此外,如果你不是广发银行的合伙人,而且不介意支付一点钱,那么我会试试TotalView。它有一点陡峭的学习曲线(它绝对可以更直观),但它是我在任何平台上使用过的最好的c++调试器,并且可以扩展以自定义方式内测你的对象(因此允许你将STL列表视为一个实际的对象列表,而不是一堆令人困惑的内部数据成员,等等)。

你没有提到你使用的是Windows还是UNIX。

在UNIX系统上,KDevelop很好,但我使用KDbg,因为它易于使用,也可以用于非KDevelop开发的应用程序。

Eclipse在这两个平台上都很好。

在Windows上,有一个叫做Wascana Desktop Developer的很棒的包,它是Eclipse CDT和MinGW,它们都经过了很好的打包和预配置,使痛苦最小化。这是我发现的在Windows上开发GNU代码最好的工具。

我已经使用了所有这些调试器,没有一个像MS Dev Studio一样好。Eclipse/Wascana可能是最接近的,但它确实有局限性,比如不能进入dll,而且它在检查变量方面做得不太好。