函数指针

1.函数指针的初始化:

int f(int);

int (*pf)(int) = &f;

第二个声明创建了函数指针pf,并把它初始化为指向函数f。函数指针的初始化也可以通过一条赋值语句来完成。在函数指针的初始化之前具有f的原型很重要,否则编译器就无法检查f的类型是否与pf所指向的类型一致。

2.初始化表达式中的&操作符是可选的,因为函数名被使用时总是由编译器把它转换为函数指针。&操作符只是显式地说明了编译器将隐式地说明了编译器将隐式执行的任务。

3.在函数指针被声明并且初始化之后,就可以使用三种方式调用函数:

int ans ;

ans = f(25);

ans = (*pf)(25);

ans = pf(25);

第一条语句简单地使用名字调用函数f,但它执行过程可能和你想象的不太一样,函数名f首先被转换为一个函数指针,该函数指针指定函数在内存中的位置。然后,函数调用操作符调用该函数,执行开始于这个地址的代码。

第二条语句对pf执行间接访问操作,它把函数指针转换为一个函数名。这个转换并不是真正需要的,因为编译器在执行函数调用操作符之前又会把它转换回去。不过这条语句的效果和第一条语句是完全一样的。

第三条语句和前两条语句的效果是一样的。间接访问操作并非必需的,因为编译器需要的是一个函数指针。

原文地址:https://www.cnblogs.com/shiheyuanfang/p/13267582.html