#include<stdio.h>
int square(int num){
return num * num;
}
int main(){
int num;
int (*fp)(int);
printf("please input a number:");
scanf("%d",&num);
//“如果在程序中定义了一个函数,在编译时会把函数的源代码转换为可执行代码并分配一段存储空间。
// 这段内存空间有一个起始地址,也称为函数的入口地址。
// 函数名代表函数的起始地址。调用函数时,从函数名得到函数的起始地址,并执行函数代码。”
// 摘自《C程序设计(第五版)》-谭浩强,P265页。
fp = square;//函数名等于函数的地址。
//通过fp = square语句使得fp指向函数的入口,
//因此通过fp指针就能找到函数square的代码存放在哪里,从而调用并执行这段代码
printf("fp = 0x%x %d\n",fp,(*fp)(num));
//下面这种方式也可以,但是不理解。
printf("fp = 0x%x %d\n",fp,fp(num));
return 0;
}
为什么第二种方式也可以呢?不是很理解。
又看了一遍课,懒猫老师说C语言支持以下的两种方式。