我正在处理一些x86代码,我知道大多数情况下jmp命令是用于什么以及它做什么的,但这一行绝对让我感到困惑。
jmp *0x804a0e0(,%eax,4)eax依赖于早期的输入,应该是int。0x804a0e0包含60 (基数10)。谁能解释一下这句话的意思吗?
发布于 2014-05-06 03:38:50
jmp *0x804a0e0(,%eax,4)
这个指令非常简单:给定函数指针的array (数组从地址0x804a0e0开始)和索引i (存储在%eax中),调用函数,指向的指针存储在array[i]中。
您很可能在C++中遇到这样的指令(虚拟函数调用是这样实现的)。
使用(gdb) info symbol 0x804a0e0将告诉您array实际上对应于什么全局。
https://stackoverflow.com/questions/23484010
复制相似问题