我正在使用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
答案 0 :(得分:4)
除了写入内存之外,您的源代码没有任何副作用。编译器将这些写入删除为无用。
如果在调试模式(而不是Release)中编译它或者关闭一些编译器优化,你可能会有更好的运气。
或者,将保留对定义为volatile
的变量的访问权限,因此您可以在代码中添加volatile
。