printf_s在debug模式下打印未初化变量

Posted Distance、

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了printf_s在debug模式下打印未初化变量相关的知识,希望对你有一定的参考价值。

今天在调试内核输出的时候发现的

printf_s在打印已经初始化的变量的时候正常输出,但是在打印未初始化的时候出现未料到的数据。

原码是这样的

char buf[15];
    DWORD bfread;
    ReadFile(device, buf, 10, &bfread, NULL);
    for (int i = 0; i < 10; i++)
    {
        printf_s("%x\n", buf[i]);
    }

输出成了这样技术分享

按理一个char为一个字节,输出不可能4个字节,于是我用OL打开

技术分享

这是主入口函数

技术分享

关键在于movsx这个指令,他扩展了一个符号位字节放到EAX里,然后打印出来。

这样就明显了,实际printf_s函数会在打印之前将数据符号扩展为32位再打印出来。

那么我继续,如果初始化了,那么在何时初始的呢,改变原码再打开技术分享

在原码定义处初始化,并非按照我原来的预想在主函数一开始初始化~~

 

以上是关于printf_s在debug模式下打印未初化变量的主要内容,如果未能解决你的问题,请参考以下文章

c++内存示例23未初化复制,默认构造

调试教程

调试教程

Release模式下无法调试打印对象的解决方式

tomcat一直打印debug信息,怎么去掉

为什么Xcode调试模式下, lldb调试器打印任何对象都为空, 鼠标指向对变量时显示为nil?