函数指针解引用:揭开谜底
在 C 编程中,函数指针是存储函数地址的变量。然而,与常规变量不同,取消引用函数指针的行为是独特的。
为什么取消引用函数指针不会产生预期的结果?关键在于理解函数值如何在右值上下文中运行(它们被用作值而不是位置)。在 C 中,右值上下文中的函数值会自动转换为指向其原始函数值的指针。
使用 * 取消引用此指针时,将检索原始函数值。但是,该值会立即重新转换为指针,从而创建指针转换的无限循环。问题中提供的代码说明了这种行为:
#include <stdio.h> void hello() { printf("hello"); } int main(void) { (*****hello)(); }
此代码本质上通过一系列函数指针取消引用调用 hello 函数五次。然而,这些取消引用实际上并不执行该函数;而是它们只是检索函数指针,然后将其转换回指针。最终结果是一系列指针操作,但没有实际的函数调用。
要理解为什么会发生这种情况,请考虑一个类似的实验:
int x; // Regular variable int *px = &x; // Pointer to the variable *px = 5; // Modifying the variable through the pointer
在此代码中,取消引用指针 * px 允许我们修改变量 x 的值。但是,对于函数指针,取消引用不会修改函数本身,而是检索其地址。
存在这种区别是因为函数在 C 中是不可变的,这意味着它们不能被修改。它们只能作为指针被调用或传递。因此,不需要取消引用函数指针来修改其行为。
总之,取消引用函数指针并不执行该函数,而是检索其地址。然后该地址立即重新转换为指针,从而导致指针转换的无限循环。此行为是 C 中右值上下文中函数值的独特功能,可以方便地使用函数指针,而无需显式使用与号 (&) 进行地址引用。
以上是为什么在 C 中取消引用函数指针不执行该函数?的详细内容。更多信息请关注PHP中文网其他相关文章!