从汇编看,vc调用API函数和自定义函数的区别

来源:互联网 发布:内饰 防御机制 知乎 编辑:程序博客网 时间:2024/04/30 04:10


API函数调用:是先得到API函数代码地址的导入地址,再得到API函数代码地址,再执行代码
内部实现函数调用:是先调"内部实现函数"的"函数入口的静态表(@ILT)"的对应函数,再执行真正函数代码。

比如:
调MessageBoxA(NULL, "Test", "Test", MB_OK);执行汇编代码为:dword ptr [__imp__MessageBoxA@16 (0042b2cc)],0042b2cc实际上是MessageBoxA在导入函数的(unsigned *) RVA2Ptr(pIMAGE_IMPORT_DESCRIPTOR->FirstThunk)+i,实际上是API函数代码地址的导入地址

调自定义函数MyMessageBoxA(NULL, "Test", "Test", MB_OK);执行汇编代码为:
call        @ILT+25(MyMessageBoxA) (0040101e),@ILT实际上是函数入口的静态表