5

下面的代码没有做任何有趣的事情,但神秘的是为什么 Dr Memory 会认为有一个单元化读取?有任何想法吗?

#include <memory>

int main(int argc, const char* argv[])
{
    int aa[] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};

    std::unique_ptr<int[]> p {new int[10]};

    for (auto i = 0; i < 10; ++i) {
        p[i] = aa[i];
    }

    return 0;
} // <-- Dr Memory says UNINITIALIZED READ here

编辑:这是完整的错误详细信息。

Error #1: UNINITIALIZED READ: reading 0x0028ff20-0x0028ff24 4 byte(s)
# 0 __mingw_glob                              [src/main.cpp:14]
# 1 _setargv                                  [src/main.cpp:14]
# 2 __mingw_CRTStartup
# 3 mainCRTStartup
# 4 ntdll.dll!RtlInitializeExceptionChain    +0x62     (0x772c8fe2 <ntdll.dll+0x38fe2>)
# 5 ntdll.dll!RtlInitializeExceptionChain    +0x35     (0x772c8fb5 <ntdll.dll+0x38fb5>)
Note: @0:00:00.297 in thread 9780
Note: instruction: cmp    (%esi) $0x0040a11e
4

1 回答 1

2

您的函数中指示的main行不是发生错误的行。__mingw_glob如堆栈跟踪所示,错误发生在调用任何代码之前。(这是扩展命令行上传递的文件名通配符的函数。在 Linux 上这项工作由 shell 完成,但在 Windows 上由 C 运行时负责。)

换句话说,它发生在mingw图书馆里。这很可能是无害的误报,您应该简单地添加排除项。

我认为 Dr Memory 可能错误地将其识别为未初始化,因为它是在您的任何代码运行之前由操作系统初始化的,或者是在初始化 DrMemory 之前运行的代码,或者因为它被传递给了一个不在事实上读取内存,但只写入它。

为什么它在您的函数中显示错误的行?

默认情况下,调试器会尝试向您显示相关信息。由于您的代码通常更有可能是错误的而不是库代码,因此调试器将在调用堆栈上显示您的代码的最新实例。例如,如果在特定于实现的调用深度中发生错误,free则不太可能是库堆代码出错,因此您调用的代码free将被识别为可能的罪魁祸首。

在您的情况下,调用堆栈上没有您的代码,因此该算法无法找到任何代码并显示错误的位置。

于 2015-10-09T12:04:09.583 回答