【发布时间】:2011-01-05 19:58:05
【问题描述】:
在调试模式下用 MSVC2008 编译这个简单的函数:
int __cdecl sum(int a, int b)
{
return a + b;
}
我得到以下反汇编列表:
int __cdecl sum(int a, int b)
{
004113B0 push ebp
004113B1 mov ebp,esp
004113B3 sub esp,0C0h
004113B9 push ebx
004113BA push esi
004113BB push edi
004113BC lea edi,[ebp-0C0h]
004113C2 mov ecx,30h
004113C7 mov eax,0CCCCCCCCh
004113CC rep stos dword ptr es:[edi]
return a + b;
004113CE mov eax,dword ptr [a]
004113D1 add eax,dword ptr [b]
}
004113D4 pop edi
004113D5 pop esi
004113D6 pop ebx
004113D7 mov esp,ebp
004113D9 pop ebp
004113DA ret
prolog 的某些部分我不明白:
004113BC lea edi,[ebp-0C0h]
004113C2 mov ecx,30h
004113C7 mov eax,0CCCCCCCCh
004113CC rep stos dword ptr es:[edi]
为什么需要这样做?
编辑:
按照建议删除/RTC 编译器选项后,大部分代码确实消失了。剩下的是:
int __cdecl sum(int a, int b)
{
00411270 push ebp
00411271 mov ebp,esp
00411273 sub esp,40h
00411276 push ebx
00411277 push esi
00411278 push edi
return a + b;
00411279 mov eax,dword ptr [a]
0041127C add eax,dword ptr [b]
}
现在,为什么需要:sub esp, 40h?就好像为局部变量分配了位置,尽管没有。为什么编译器会这样做?是否涉及其他标志?
【问题讨论】: