需要在IDA Pro中解释C代码

时间:2012-08-04 03:26:22

标签: c visual-c++ assembly x86 ida

我正在使用IDA Pro来反汇编以下C代码:但是看下面的反汇编,我觉得不完整。数据永远不会被初始化(根据C代码),即使它看起来似乎被加载到堆栈中,但位于00401040的过程(nullsub_1)不使用数据?我正在做出正确的评估还是我错过了什么?我使用Visual C ++ 6/2005编译C代码。

#include <stdio.h>
#include <windows.h>

struct a
{
    char s[10];
    BYTE b;
    int i;
};

a al;
void init(a);
void main()
{
    init(al);
};

void init(a c)
{
    for(int j = 0; j < 10; j++) c.s[j] = 'A';
    c.b = 10;
    c.i = 10000;
};


.text:00401000 ; int __cdecl main(int argc,const char **argv,const char *envp)
.text:00401000 _main           proc near               ; CODE XREF: start+AFp
.text:00401000
.text:00401000     argc            = dword ptr  4
.text:00401000     argv            = dword ptr  8
.text:00401000     envp            = dword ptr  0Ch
.text:00401000
.text:00401000                 mov     ecx, dword_4084C0
.text:00401006                 mov     edx, dword_4084C4
.text:0040100C                 sub     esp, 10h
.text:0040100F                 mov     eax, esp
.text:00401011                 mov     [eax], ecx
.text:00401013                 mov     ecx, dword_4084C8
.text:00401019                 mov     [eax+4], edx
.text:0040101C                 mov     edx, dword_4084CC
.text:00401022                 mov     [eax+8], ecx
.text:00401025                 mov     [eax+0Ch], edx
.text:00401028                 call    nullsub_1
.text:0040102D                 add     esp, 10h
.text:00401030                 retn
.text:00401030 _main           endp
.text:00401030
.text:00401030 ;     
.text:00401031                 align 10h
.text:00401040
.text:00401040
.text:00401040
.text:00401040 nullsub_1       proc near               ; CODE XREF: _main+28p
.text:00401040                 retn
.text:00401040 nullsub_1       endp

1 个答案:

答案 0 :(得分:4)

除了写入内存之外,您的源代码没有任何副作用。编译器将这些写入删除为无用。

如果在调试模式(而不是Release)中编译它或者关闭一些编译器优化,你可能会有更好的运气。

或者,将保留对定义为volatile的变量的访问权限,因此您可以在代码中添加volatile