- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我查看了我的c代码的反汇编,发现指向函数的指针实际上指向了jmp
指令,并没有指向内存中函数的真正开始(不指向push ebp
指令,表示函数帧的开始)。
我有以下功能(基本上什么都不做,这只是一个例子):
int func2(int a, int b)
{
return 1;
}
我尝试打印函数的地址 - printf("%p", &func2);
我查看了我的代码的反汇编,发现打印的地址是汇编代码中jmp
指令的地址。我想获得代表函数帧开始的地址。有什么方法可以从 jmp
指令的给定地址计算出来吗?此外,我有代表 jmp
指令的字节。
011A11EF E9 CC 08 00 00 jmp func2 (011A1AC0h)
我怎样才能得到代表内存中函数帧开始的地址(在那种情况下是011A1AC0h
),只能从jmp
指令的地址和从表示 jmp
指令本身的字节?我看了一些相关资料,发现它是相对jmp
,这意味着我需要将jmp
持有的值添加到的地址>jmp
指令本身。不确定这是否是解决方案的好方向,如果是,我怎样才能获得 jmp
持有的值(value)?
最佳答案
E916 是带有 rel32 偏移量的 jmp 指令的 Intel 64 和 IA-32 操作码。接下来的四个字节包含偏移量。您的反汇编程序将它们显示为“CC 08 00 00”,但这是相反的;偏移量为 000008CC16,即 225210。偏移量是一个带符号的 32 位值,添加到 EIP 寄存器以获得跳转目标的地址。 EIP包含下一条要执行的指令的地址。
因此,在这种特定情况下,取跳转指令之后的字节地址并加上 32 位偏移量。
但是:
我在 Intel 64 和 IA-32 手册中统计了 11 种形式的 jmp 指令。当您对源代码或编译器开关进行轻微更改并重新编译时,谁知道编译器可能会使用什么?您需要准备解码任何形式的 jmp 指令,或者编译器可能使用的其他指令。
英特尔在其架构中有一些传统的 segmentation 市场特征。您系统上的代码段可能是一件大事,因此您不必担心,但我不能提供保证。
您的编译器可能已将此 jmp 指令用作为指针创建值的便捷方法,而不是使用例程的入口点(函数执行通常开始的指令的正确术语,而不是帧),因为它使链接器进行重定位工作,而不是要求编译器在运行时插入指令来完成该工作(具体来说,在必须评估函数地址时,以便将其分配给指针)。这有点像猜测,但编译器下次可能会做其他事情。您在正常计算之外进行了大量工作。
关于c - 指向函数的指针指向c中的jmp指令,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48613419/
C语言sscanf()函数:从字符串中读取指定格式的数据 头文件: ?
最近,我有一个关于工作预评估的问题,即使查询了每个功能的工作原理,我也不知道如何解决。这是一个伪代码。 下面是一个名为foo()的函数,该函数将被传递一个值并返回一个值。如果将以下值传递给foo函数,
CStr 函数 返回表达式,该表达式已被转换为 String 子类型的 Variant。 CStr(expression) expression 参数是任意有效的表达式。 说明 通常,可以
CSng 函数 返回表达式,该表达式已被转换为 Single 子类型的 Variant。 CSng(expression) expression 参数是任意有效的表达式。 说明 通常,可
CreateObject 函数 创建并返回对 Automation 对象的引用。 CreateObject(servername.typename [, location]) 参数 serv
Cos 函数 返回某个角的余弦值。 Cos(number) number 参数可以是任何将某个角表示为弧度的有效数值表达式。 说明 Cos 函数取某个角并返回直角三角形两边的比值。此比值是
CLng 函数 返回表达式,此表达式已被转换为 Long 子类型的 Variant。 CLng(expression) expression 参数是任意有效的表达式。 说明 通常,您可以使
CInt 函数 返回表达式,此表达式已被转换为 Integer 子类型的 Variant。 CInt(expression) expression 参数是任意有效的表达式。 说明 通常,可
Chr 函数 返回与指定的 ANSI 字符代码相对应的字符。 Chr(charcode) charcode 参数是可以标识字符的数字。 说明 从 0 到 31 的数字表示标准的不可打印的
CDbl 函数 返回表达式,此表达式已被转换为 Double 子类型的 Variant。 CDbl(expression) expression 参数是任意有效的表达式。 说明 通常,您可
CDate 函数 返回表达式,此表达式已被转换为 Date 子类型的 Variant。 CDate(date) date 参数是任意有效的日期表达式。 说明 IsDate 函数用于判断 d
CCur 函数 返回表达式,此表达式已被转换为 Currency 子类型的 Variant。 CCur(expression) expression 参数是任意有效的表达式。 说明 通常,
CByte 函数 返回表达式,此表达式已被转换为 Byte 子类型的 Variant。 CByte(expression) expression 参数是任意有效的表达式。 说明 通常,可以
CBool 函数 返回表达式,此表达式已转换为 Boolean 子类型的 Variant。 CBool(expression) expression 是任意有效的表达式。 说明 如果 ex
Atn 函数 返回数值的反正切值。 Atn(number) number 参数可以是任意有效的数值表达式。 说明 Atn 函数计算直角三角形两个边的比值 (number) 并返回对应角的弧
Asc 函数 返回与字符串的第一个字母对应的 ANSI 字符代码。 Asc(string) string 参数是任意有效的字符串表达式。如果 string 参数未包含字符,则将发生运行时错误。
Array 函数 返回包含数组的 Variant。 Array(arglist) arglist 参数是赋给包含在 Variant 中的数组元素的值的列表(用逗号分隔)。如果没有指定此参数,则
Abs 函数 返回数字的绝对值。 Abs(number) number 参数可以是任意有效的数值表达式。如果 number 包含 Null,则返回 Null;如果是未初始化变量,则返回 0。
FormatPercent 函数 返回表达式,此表达式已被格式化为尾随有 % 符号的百分比(乘以 100 )。 FormatPercent(expression[,NumDigitsAfterD
FormatNumber 函数 返回表达式,此表达式已被格式化为数值。 FormatNumber( expression [,NumDigitsAfterDecimal [,Inc
我是一名优秀的程序员,十分优秀!