草庐IT

DEBUGGING

全部标签

C++ 参数的值在 std::vector 中的堆栈帧之间发生变化

我遇到了一个非常奇怪的错误,我希望有人能解释一下。我有一个简单的std::vector,其中V3x是一个3dvector(线性代数类型)。以下代码导致std::length_error抛出异常:std::vectorvertices;intvertexCount=computeVertexCount();vertices.resize(vertexCount);//throwsstd::length_error我已经验证computeVertexCount()返回值35,远低于vector::max_size()所以它不可能要求太多内存。我将异常追溯到std::vector的定义中,到

c++ - 关于调试,多线程的面试题

我昨天有电话面试问题。面试官问我是否遇到过任何具有挑战性的调试问题?我告诉他我曾经在调试别人的代码时遇到过问题,我花了3-4天的时间才解决这个问题。我使用Windbg、符号和故障转储来解决问题。现在这足以说明问题了吗?面试官期望什么?我不知道还能说些什么,我很久以前就遇到过这个问题,无法解释所有细节......这个问题很常见,我不确定正确答案是什么?还有一个很常见的问题:您是否处理过多线程应用程序?你怎么能找出死锁?答:要找到死锁,我们可以查看内存中进程的快照,并查看正在等待的线程。那么下一个问题:如何避免死锁?使用waitformultipleobjects维护关键部分的顺序你们怎么

c++ - 未命中断点 - "the module did not load at the default load address"

我正在尝试调试CPPUnitTests,断点设置在作为待测试DLL(C++非托管dll)一部分的文件中。我将CPPunit测试程序进程附加到打开项目的visualstudioIDE,处于native模式(也尝试过托管+native),然后运行测试,但断点根本没有命中。断点似乎没问题(全红点)。我在DebugBuild中构建了所有必要的DLL。我去Debug->Windows->Modules检查测试程序进程是否加载了我正在调试的DLL,它确实加载了,并且SYmbol文件也被加载了,但是DLL的名称中有一个感叹号和当我将鼠标悬停在它上面时,它说“模块没有在默认加载地址加载”。我该如何解决

c++ - 为什么从析构函数调用时 qCritical 或 qDebug 不起作用?

我有一个多线程应用程序,我最初是使用Qt4.6和QtCreator2.2(或可能是2.1)开发的,最近我升级到Qt4.7和QtCreator2.3(这都是在Windows中)。我之前一直在通过调用qCritical()来测试应用程序中各种线程和对象的销毁顺序。在析构函数中。它很容易确认东西正在按照我预期的顺序销毁。但是,在升级到较新版本后,我注意到消息并不总是显示在QtCreator的“应用程序输出”面板中。消息的顺序总是正确的,但在某个随机点,输出只是停止显示。有时根本不显示任何输出。尽管如此,我可以确认对象正在被销毁并且我的应用程序退出时没有错误。使用qDebug()问题依旧来显示

c++ - 如何调试加载共享库

我有一个使用uclibc在MIPSCPU上运行的多进程程序,它是用gcc4.5.3编译的。其中一个过程(名称为“tv”)需要链接到一个共享库(libtest.so),该库也是我编写的。“tv”进程是用C++编写的,而libtest.so是用C编写的。我还从libtest.so转储了elfheader,它同时设置了PIC和CPIcflags,所以我认为创建库是可以的。当我尝试运行该程序时,除“tv”进程外,所有进程都正常启动。没有错误信息。当我使用ps检查它的状态时,它已经变成了一个僵尸进程。我试过以下方法如果我从链接进程中删除libtest.so,并删除对libtest.so的所有引用

c++ - 无法使用 GDB 进入共享库中的函数

我正在尝试调试一个使用GDB从许多共享库构建的应用程序。gdb的开始:prompt$gdbGNUgdb(GDB)RedHatEnterpriseLinux(7.2-50.el6)Copyright(C)2010FreeSoftwareFoundation,Inc.LicenseGPLv3+:GNUGPLversion3orlaterThisisfreesoftware:youarefreetochangeandredistributeit.ThereisNOWARRANTY,totheextentpermittedbylaw.Type"showcopying"and"showwarra

c++ - 从内存转储中找出线程消息队列中的消息计数

我知道在任何给定时间通过任何类型的WinAPI调用都无法确定线程队列中有多少消息。我有一个应用程序无法运行,因为PostMessage有时会失败(可能是由于队列增长到10000,尽管我不明白它怎么会增长到这么大)。这是一个间歇性问题,我在它发生的那一刻进行了几次内存转储。显然队列必须在某个地方,本文解释了如何获取它http://moyix.blogspot.com/2008_09_01_archive.htmlEachthreadinWindows(representedbythe_ETHREADstrucutre)hasafieldinitsThreadControlBlock(or

c++ - 如何深入研究 shared_ptr [Netbeans、clang++、gdb]

我正在使用NetbeansC++8.0.2clang++(Ubuntuclang版本3.6.0-2ubuntu1(tags/RELEASE_360/final)(基于LLVM3.6.0))gdb(GNUgdb(Ubuntu7.9-1ubuntu1)7.9)在我的“C++简单测试”中,每当我检查一个shared_ptr变量时,我看到的所有值都是:std::shared_ptr(count1,weak0)0x64d3a0或类似的。无法深入了解它实际指向的值。即使变量窗口中的TreeView显示了其中一个扩展器图标,当我单击它时它也会消失。当我尝试取消引用它或在“表达式”窗口中调用它的get

c++ - backtrace - 隐藏标准库和提升调用

我正在查看gdb中的回溯,它看起来非常困惑,因为对标准库和boost进行了所有调用。例如。我在调用堆栈上看到boost::bind和std::allocator,以及对标准库或Boost的其他几个类似调用。我想我会发现让回溯只显示我的程序中明确定义的函数会很有帮助。更好的是,如果我可以快速配置backtrace命令以在需要时显示或隐藏std和boost调用,这将有进一步的帮助。知道如何从调用堆栈中完全隐藏boost或配置回溯以打开和关闭boost日志记录吗? 最佳答案 没有内置方法可以做到这一点。不过,可以通过编写一个Python“

c++ - 如何在 Visual Studio 中的 DLL 上设置断点?

我正在研究一个DLL(用C++编写)的源代码,它是另一个程序的插件。没有文档,我也没有主程序的源代码。我试图找出主程序调用DLL的位置和时间。有超过100个函数被标记为DllExport,因此仅此一项并没有多大帮助。为此,如果我每次执行到我的DLL中的代码时都可以触发一个断点,那就太好了。那或将其记录在某处。这可能吗?如何实现? 最佳答案 呸,这是你的要求。但老实说,这可能是非常有用的东西,即使对于其他场景也是如此。我认为您可以实现此目的的最简单方法是使用WinDbg并在那里设置断点。使用WinDbg你可以做这样的事情(假设你的图像