在 C 中解引用函数指针的行为可能会产生意想不到的结果。例如,下面的代码片段似乎对函数指针执行了过多的取消引用,但输出保持不变:
#include<stdio.h> void hello() { printf("hello"); } int main(void) { (*****hello)(); }
要理解这种行为,需要对于澄清 C 中函数指针的语义至关重要。虽然函数名称可能暗示函数的指针,但它们实际上表示函数代码的地址。因此,取消引用函数指针不会直接执行该函数,而是返回一个函数指示符,该指示符会迅速转换回函数指针。
在示例代码中,重复取消引用 hello 不会执行函数重复多次。相反,每次取消引用都会创建一个新的函数指示符,然后将其转换回函数指针。最终的表达式 (*****hello) 只是计算为 hello 的函数指针,并通过 () 调用它会按预期执行该函数。
另一个奇特的地方C 中函数指针的一个方面是它们在特定上下文中函数值和指针之间的隐式转换。当函数值出现在右值上下文(用作值而不是位置的任何上下文)中时,它会自动转换为函数指针。此行为扩展到嵌套函数值,其中每个取消引用都会返回一个指向原始函数的函数指针。
虽然函数指针取消引用的行为最初看起来令人费解,但它可能是在某些场景下是有益的。通过避免在传递函数指针时显式使用 &,代码变得更加简洁和可读。此外,通过函数指针和函数名称调用函数之间的对称性允许两种形式之间的无缝转换。
以上是为什么在 C 中重复引用函数指针不会导致多次函数调用?的详细内容。更多信息请关注PHP中文网其他相关文章!