gpt4 book ai didi

c++ - 从命令行运行到 "Run without Debugging"的不同行为

转载 作者:太空狗 更新时间:2023-10-29 21:07:20 25 4
gpt4 key购买 nike

在这里挠头:如果从 Visual Studio 2010 启动,我有一个应用程序在 Debug+Release 中运行良好,在 Debug 和“Run without Debugging”中都运行良好。如果我使用相同的设置从命令行运行相同的应用程序,我会看到不同的行为。特别是,运行不同的代码是:

const List& vl = nDesc.Get<List> ("slots");

int index = 0;
for (auto it = vl.begin (), end = vl.end (); it != end; ++it)
{
desc.units [index++] = Parse (Tree (*it));
// If I access it again here, e.g.
// Log::Info (std::distance (vl.begin (), it))
// this works always
}

我假设这是一个竞争条件,但代码是完全单线程的。有趣的是,添加一些随机代码并不能使它工作(即仅仅记录一个字符串是不够的。)哦,这个循环只运行一次,永远。

desc中的数据是相同的,在循环显示相同数据已写入后将其转储到文件中。在那段代码中上下移动循环没有帮助;将 auto 更改为 List::const_iterator 也没有帮助。

有什么想法可以从哪里开始调试吗?

[更新] 禁用此函数的优化并不能为 Release 修复它,但我可以附加调试器并看到其中的所有内容都按预期工作。但是我没有得到正确的程序行为。 Stills 也适用于“无需调试运行”和“带调试运行”。

最佳答案

我怀疑问题与未初始化的堆内存块有关。

在不调试的情况下启动它与将其附加到调试器和从调试器启动它之间的主要区别在于,在第二种情况下使用 Windows 调试堆。

Windows 调试堆使用特定模式 (0xBAADF00D IIRC) 预填充传递给客户端的内存,并在附加调试器的可执行文件启动时激活。即使这样做是为了更容易发现未初始化的内存错误(因为它用“奇怪”的模式填充内存),在这种情况下它也可能掩盖了您的问题,因为只有在没有使用调试堆时它才会变得明显(因此未初始化的内存块可能用零填充)。

请注意,这个特定的代码块可能只是冰山一角,问题可能起源于不同的位置并在这里出现。

祝你好运,我在第三方库中也遇到过这种问题,尽管搜索了几天,我还是不得不放弃。

(顺便说一句,Windows 调试堆与 CRT 调试堆无关,后者仅在可执行文件的调试构建中激活,并且 IIRC,它使用 0xCD 模式填充内存)

关于c++ - 从命令行运行到 "Run without Debugging"的不同行为,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5352762/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com