主要是为了掌握对指针函数的应用,有以下三个例子
例子1为:
此程序为显示一个数组arr[4];
结构图如下所示:
源代码如下:
#include<stdio.h>
#include<stdlib.h>
void foreach(int arr[], int len, void(*pf)(int *p)){
int i;
for(i=0;i<len;i++){
pf(arr+i);
}
void clear(int *p){
*p=0;
}
void add(int *p){
static int cnt=0;
*p=++cnt;
}
void show(int *p){
printf("%d\t",*p);
}
int main(void){
int arr[4];
foreach(arr,4,clear);
foreach(arr,4,add);
foreach(arr,4,show);
}
程序运行结果为:
例子2为:
此程序为一个排序结构,可以选择从大到小从小到大;
结构图如下:
源代码如下:
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define SWAP (a,b)({\
int t=a;\
a=b;\
b=t;\
})//切勿忘记‘\’
void sort(int arr[],int len,void (*pf)(int ,int)){
int i;
int j;
for(i=0;i<len;i++){
for(j=0;j<i+1;j++){
if(pf(arr[i],arr[j])==1)
SWAP(arr[i],arr[j]);
}
}
}
void rule1(int a,int b){
return a<b;
}
void rule2(int a,int b){
return a>b;
}
void show(int arr[],int len){
int i;
for(i=0;i<len;i++){
printf("%d\t"arr[i]);
}
}
int main(void){
int arr[7]={1,2,5,7,10,21,9};
sort(arr,7,rule2);
show(arr,7)
}
程序运行结果为:
例子3为:
n!
typedef和函数指针的应用
typedef void (Func *) (int)起别名为Func(就是去掉typedef 和Func后剩余的类型 形参。类似这样的类型都可以用Func来代替)
例如下边的代码
#include<stdio.h>
#include<stdlib.h>
typedef void (*Func)(int);
Func func(int s,Func h){//==void ((*func)(int s,void (*h)(int)))(int)
h(s);
return h;
}
void rule(int a){
printf("%d\n",pre(a));
}
int pre(int n){
if(n==0)return 1;
else
return n*pre(n-1);
}
int main(void){
void (*pf)(int);
pf=func(4,rule);
pf(3);
return 0;
}
运行结果如下图:
以上三个例子为对函数指针的简单掌握。