/*
看到 ilovenet大作“有没有试过将函数作为参数(parameter)来传递?”
(http://www.csdn.net/develop/Read_Article.asp?Id=18162).
颇有感触,下面是我关于“函数指针”和作为参数传递的实践内容,
不多言,大家亲自体会一下即知。
本人水平有限,欢迎指正(绝不是谦虚^_^)。
*/
//程序如下
//Test on windows 2000 + VC 6.0
//
//\\====================================\\//
#include "stdafx.h"
typedef bool (*compfunc)(int ,int );
//函数的指针
//compfunc的意思就是:
/*
指向返回值是bool的函数指针
compfunc a ====== bool (*a)(int ,int)
*/
//两个简单的函数,执行着相反的功能
bool littletobig(int a,int b) {return b<a;}
bool bigtolittle(int a,int b) {return b>a;}
void exchange(int &a, int &b){int temp;temp = a,a = b,b = temp;}
//函数的指针为参数
//任意一个数组排序了
//当传入littletobig,从小到大排序,反之bigtolittle,从大到小
//两种函数声明方法一样。
#if 0
void sort(int array[],const int size,bool (*comp)(int,int))
#else
void sort(int array[],const int size,compfunc comp)
#endif
{
int i = 0;
for(;i < size-1; i++){
if(comp(array[i],array[i+1]))
{
exchange(array[i],array[i+1]);
sort(array, i+1 ,comp); //递归排序
}
}
}
int main(int argc, char* argv[])
{
int arr[] = {3,4,2,1,-1,999,234,34,56,-2,-2};
//函数指针声明,一下四种情况完全相同//
//\\==================================================\\//
compfunc up = littletobig,down = bigtolittle;
sort(arr,sizeof(arr)/sizeof(int),up);
sort(arr,sizeof(arr)/sizeof(int),down);
//\\==================================================\\//
bool (*up2)(int ,int) = littletobig;
bool (*down2)(int ,int); down2= bigtolittle;
sort(arr,sizeof(arr)/sizeof(int),up2);
sort(arr,sizeof(arr)/sizeof(int),down2);
//\\=================================================\\//
compfunc funcarray[2] = {littletobig,bigtolittle};
sort(arr,sizeof(arr)/sizeof(int),funcarray[0]);
sort(arr,sizeof(arr)/sizeof(int),funcarray[1]);
//\\=================================================\\//
bool (* funcarray2[2])(int,int) = {littletobig};
funcarray2[1] = bigtolittle;
sort(arr,sizeof(arr)/sizeof(int),funcarray[0]);
sort(arr,sizeof(arr)/sizeof(int),funcarray[1]);
//\\=================================================\\//
return 0;
}
//
//
//Reference to http://www.csdn.net/develop/Read_Article.asp?Id=18162.
//
//