函数指针浅谈

发表于:2007-07-01来源:作者:点击数: 标签:
/* 看到 ilov .net 大作“有没有试过将函数作为参数(parameter)来传递?” (). 颇有感触,下面是我关于“函数指针”和作为参数传递的实践内容, 不多言,大家亲自体会一下即知。 本人水平有限,欢迎指正(绝不是谦虚^_^)。 如有错误, */ //程序如下 //Te

/*
 看到 ilov.net大作“有没有试过将函数作为参数(parameter)来传递?”
 ().
 颇有感触,下面是我关于“函数指针”和作为参数传递的实践内容,
 不多言,大家亲自体会一下即知。
 本人水平有限,欢迎指正(绝不是谦虚^_^)。
 如有错误,
*/

//程序如下
//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.ltesting.net