【C】函数指针——函数名等于函数的地址

#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语言支持以下的两种方式。
请添加图片描述


版权声明:本文为l634007854原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。