首先看看函数指针,函数名,以及它们分别与*和&结合后的值
- 程序清单
#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作函数名均可以实现函数调用