从函数到函数指针的隐式转换?

ram*_*owl 5 c++ function-pointers function

我有一个函数,它接受一个函数指针作为参数。令人惊讶的是,我可以传入一个函数指针和一个普通函数:

#include <iostream>
#include <functional>

int triple(int a) {
    return 3*a;
}

int apply(int (*f)(int), int n) {
    return f(n);
}

int main() {
    std::cout << apply(triple, 7) << "\n";
    std::cout << apply(&triple, 7) << "\n";
}
Run Code Online (Sandbox Code Playgroud)

我很困惑为什么这有效。是否存在从函数到函数指针的隐式转换?

son*_*yao 6

是的,有函数到指针的隐式转换

函数类型 T 的左值可以隐式转换为指向该函数的纯右值指针。这不适用于非静态成员函数,因为引用非静态成员函数的左值不存在。

函数指针可以用非成员函数或静态成员函数的地址初始化。由于函数到指针的隐式转换,地址运算符是可选的:

void f(int);
void (*p1)(int) = &f;
void (*p2)(int) = f; // same as &f
Run Code Online (Sandbox Code Playgroud)

这意味着在需要函数指针的上下文中使用时,函数(非静态成员函数除外)将隐式转换为函数指针,并且使用operator&是可选的。