我从代码中发现可执行文件
int main(int argc, char** argv) {
printf("Hello World\n");
return 0;
}
可以分解为(使用gcc -m32编译)
此代码来自其他人
; Variables:
; arg_4: 12
; arg_0: 8
; var_4: -4
; var_8: -8
; var_C: -12
; var_10: -16
; var_18: -24
push ebp
mov ebp, esp
sub esp, 0x18
call _main+11
pop eax ; CODE XREF=_main+6
mov ecx, dword [ebp+arg_4]
mov edx, dword [ebp+arg_0]
lea eax, dword [eax-0x1f5b+0x1fa6] ; "Hello World!\\n"
mov dword [ebp+var_4], 0x0
mov dword [ebp+var_8], edx
mov dword [ebp+var_C], ecx
mov dword [esp+0x18+var_18], eax ; method imp___symbol_stub__printf
call imp___symbol_stub__printf
xor ecx, ecx
mov dword [ebp+var_10], eax
mov eax, ecx
add esp, 0x18
pop ebp
ret
但是当我从同一代码反汇编可执行文件时(使用gcc -m32编译)
我有一个很长的反汇编代码(here is the link)
我的问题是
为什么相同代码中的指令不同?还是一样?
我可以使用任何编译器或编译器选项来给我反汇编代码吗?
您是否推荐阅读任何参考文献,以理解长汇编代码中的术语? (例如__x86.get_pc_thunk.dx)
最好的问候, 泰森
答案 0 :(得分:0)