为什么函数名相当于带有地址运算符的函数指针?
在 C 编程中,使用函数名作为函数指针相当于将取址运算符 (&) 应用于函数名称。这种与其他语言元素(例如数组)看似不一致的现象是有特定原理的。
函数名称等效的原理
根据 ANSI C90 原理文档,等效性函数指示符(函数名称)和函数指针之间的引入是为了增强便利性。通过允许这两种表示法,该语言提供了一种调用打包结构中的成员函数的简写方法。例如:
graphics.open(file) // Equivalent to (*graphics.open)(file)
函数指示符的好奇心
这种等价导致奇特但有效的语法形式:
( &f)(); f(); (*f)(); (**f)(); (***f)(); pf(); (*pf)(); (**pf)(); (***pf)();
委员会推理禁止像 (f)() 这样的形式,同时允许 a (对于int a[]) 是不必要且不方便的。
参数和返回类型中的异常
有趣的是,函数类型可以隐式转换为指向自身的指针作为参数(例如,void g(FunctionType))。但是,当用作返回类型(例如 FunctionType h();)时,它不能转换为指针。这种区别确保避免函数类型兼容性问题。
以上是为什么函数名相当于 C 中带有地址运算符的函数指针?的详细内容。更多信息请关注PHP中文网其他相关文章!