一、ELF编译的入口地址相关问题
一般而言,程序的入口地址总是0x400000, 但是在linux下, 程序的入口地址却是随机的,这是为什么呢?
因为Linux采用了地址空间配置随机加载(ASLR)技术,即在装载时将程序装载在随机地址。
GCC默认会把程序编译为位置无关的形式,以方便加载到任意位置
这样编译出来的文件类型为 DYN (Shared object file),而非EXEC (Executable file)
程序入口为elf文件中代码的相对位置,而不是在内存中的绝对位置。
如果要让程序加载到固定位置,要在编译时加上 ’ -no-pie’
gcc -g -no-pie test.c -o test
这样编出的程序类型就会变为 exec , 这样程序入口会回到0x400000