typedef BOOL (_stdcall *pConvertProgress)();
BOOL _cdecl ConvertProgress()
{
...
}
void func(pConvertProgress pProcess)
{
......
pProcess();
......
}
void main(...)
{
func(ConvertProgress);
}
C++编译器对ebp、ebx、esi和edi四个寄存器作保护,_stdcall的调用方式是使用函数本身负责恢复四个寄存器的内容,_cdecl 的调用方式是调用该函数的函数负责恢复。
对以上代码C++编译将不会报错,C++编译器在编译 pConvertProgress时因为是_stdcall 的调用方式,所以在func函数中并未在调用完pProcess()函数之后恢复ebp、ebx、esi和edi四个寄存器的内容,但在ConvertProgress中则已经对这四个寄存器的内容作了保存并且(通常情况下)ConvertProgress函数内也会使用这四个寄存器,从面导到这四个寄存器的内容发生改变,但并不做恢复寄存器内容的操作。func函数完成对ConvertProgress时也没有再恢复这四个寄存器的内容,在后面的函数操作中必将导致调用位置出错。