#include <stdio.h>
//演示函數指針的用法
int max (int x,int y)
{
return x>y?x:y;
}
int min (int x,int y)
{
return x<y?x:y;
}
int main()
{
int (*f)(int x,int y) ;
f = max;
printf("%d %d\n",max(2,6),(f)(8,4));
f = &min;
printf("%d %d\n",min(2,6),(*f)(8,4));
/*
由此可知:注意,將一個函數的地址初始化或賦值給一個指向函數的指針時,無需顯式的取得函數地址,編譯器知道隱式地獲得函數的地址,
因此在這種情況下&操作符是可有可無的,通常省略不用。
類似的,爲了調用函數指針所指向的函數而對指針進行解引用操作也是不必要的,因爲編譯器可以幫你解引用:
(*fp)(12); //顯式地解引用
fp(12); //隱式地解引用,結果相同
*/
typedef int (*PTRFUN) (int x,int y);//關於typedef定義類型
PTRFUN pf = max;
printf("%d\n",(pf)(8,4));
return 0;
}
#include <stdio.h>
typedef int (*print) (int);
int fun1(int i)
{
return 2*i;
}
void fun2(int j,print p) //函數指針做形參
{
for(int k=0;k<j;k++)
printf("%d\t",p(k));
}
int main()
{
int n = 10;
fun2(n,fun1);
return 0;
}
#include <stdio.h>
//演示函數指針數組的使用
int add(int x,int y)
{
return x+y;
}
int subtract(int x,int y)
{
return x-y;
}
int multiply(int x,int y)
{
return x*y;
}
int divide(int x,int y)
{
return x/y;
}
int main()
{
int (*p[4])(int a,int b) = {add,subtract,multiply,divide};
for(int i=0;i<4;i++)
{
printf("%d\n",p[i](10,2));
}
return 0;
}