//C代码如下所示:
#include <stdio.h>
int add(int a, int b)
{
return a+b;
}
int main( void )
{
int a,b,c;
a=1;
b=2;
c=add(a,b);
printf("%d\n",c);
return 0;
}
//几个寄存器的含义
ebp:基址指针 esp:堆栈指针
eax:累加器 ebx:基址寄存器
ecx:计数寄存器 edx:数据寄存器
esi:源变址寄存器 edi:目的变址寄存器
eip:指令指针
ILT:INCREMENTAL LINK TABLE的缩写,这个@ILT其实就是一个静态函数跳转的表,它记录了一些函数的入口然后跳过去,
每个跳转jmp占一个字节,然后就是一个四字节的内存地址,加起为五个字节。比如代码中有多处地方调用add函数,
别处的调用也通过这个ILT表的入口来间接调用,而不是直接call该函数的偏移,这样在编译程序时,如果add函数更新了,
地址变了,只需要修改跳表中的地址就可以,有利于提高链接生成程序的效率。这个是用在程序的调试阶段,当编译