got表和plt表在程序执行过程中的作用

背景

这是前面文章中的演示程序,这个指令为在Add函数里面调用的printf函数,那么为什么printf后面会跟着plt呢?

作用

为提高CPU的利用效率,程序在编译的时候会采用两种表进行辅助,即plt表和got表

plt表为(Procedure Link Table),是程序链接表。而got表为(Global Offset Table),是一个存储外部库函数的表,全局偏移表。

当程序在第一次运行的时候,会进入已被转载进内存中的动态链接库中查找对应的函数和地址,并把函数的地址放到got表中,将got表的地址数据映射为plt表的表项;
在程序二次运行的时候,就不用再重新查找函数地址,而是直接通过plt表找到got表中函数的地址,从而执行函数的功能了。

查看got表

1
objdump -R stack

参考

https://rj45mp.github.io/linux的plt表和got表在pwn中的利用