首先看看函数指针,函数名,以及它们分别与*和&结合后的值
- 程序清单
#include<stdio.h> void func(void){puts("成功调用");}; int main() { void(*p_func)(void)=func; puts("func是函数名,p_func是指向该函数的指针,那么有:"); printf("func=%p\n*func=%p\n&func=%p\ \np_func=%p\n*p_func=%p\ \n&p_func=%p",func,*func,&func,p_func,\ *p_func,&p_func); //puts("\n接着我们尝试用上述变量调用函数:"); //func(); //(*func)(); //(&func)(); //(p_func)(); //(*p_func)(); return 0; }
- 执行结果
func是函数名,p_func是指向该函数的指针,那么有: func=004015C0 *func=004015C0 &func=004015C0 p_func=004015C0 *p_func=004015C0 &p_func=0061FECC
可见==func==,==func==,==&func==,==p_func==,==p_func==代表的值都是func()函数的地址 ( &p_func是指针的地址 )
再来看看将它们分别作为函数名的结果
- 程序清单
#include<stdio.h> void func(void){puts("成功调用");}; int main() { void(*p_func)(void)=func; puts("func是函数名,p_func是指向该函数的指针,那么有:"); printf("func=%p\n*func=%p\n&func=%p\ \np_func=%p\n*p_func=%p\ \n&p_func=%p",func,*func,&func,p_func,\ *p_func,&p_func); puts("\n接着我们尝试用上述变量调用函数:"); func(); (*func)(); (&func)(); (p_func)(); (*p_func)(); return 0; }
==func==,==p_func==,==p_func==,==func==,==&func==作函数名
- 源程序
puts("\n接着我们尝试用上述变量调用函数:"); func(); (*func)(); (&func)(); (p_func)(); (*p_func)(); return 0; }
- 编译运行结果
func是函数名,p_func是指向该函数的指针,那么有: func=004015C0 *func=004015C0 &func=004015C0 p_func=004015C0 *p_func=004015C0 &p_func=0061FECC 接着我们尝试用上述变量调用函数: 成功调用 成功调用 成功调用 成功调用 成功调用
可见==func==,==p_func==,==p_func==,==func==,==&func==作函数名均可以实现函数调用
来源:https://www.cnblogs.com/BAIDI-HOME/p/12298164.html