C语言函数作为参数
为了满足DRY思想,减少代码的重复性,考虑将函数作为参数传入另一函数中。C语言是可以将函数作为函数参数的。
用到的方法是函数指针。
首先需要明确的是, 在C语言中,函数名就是函数的首地址,所以将函数作为函数参数的思路是将函数地址传入,形参是一个指针类型的变量,形参的基类型为函数原型。
参数原型为:
ElemType(*FunctionName)(ElemType, ElemType, ......)
其中:ElemType
为声明(如int, float, double,struct等)
以冒泡排序为例借助判断大小函数进行数组排序的具体实现方法如下:
#include <stdio.h>
#define YES 1
#define NO 0
///*判断函数,进行元素大小判断,increase判断大小比较*/
int compare(int a, int b, int increase)
{
if (increase > 0) {
if (a > b) return YES;
else return NO;
}
else
{
if (a < b) return YES;
else return NO;
}
}
/*冒泡排序进行数组排序*/
void OrderArr(int arry[], int(*compare)(int, int, int), int length, int increase = 1)
{
for (int i = 0; i < length - 1; i++)
{
for (int j = 0; j < length - i - 1; j++)
{
if (compare(*(arry + j), *(arry + j + 1), increase))
{
int temp = *(arry + j + 1);
*(arry + j + 1) = *(arry + j);
*(arry + j) = temp;
}
}
}
}
/*输出函数*/
void Print(int a[], int length)
{
for (int i = 0; i < length; i++)
{
printf("%d ", *(a + i));
}
printf("\n");
}
int main()
{
int a[5] = { 1, 4, 2, 6, 3 };
//增序排列数组
OrderArr(a, compare, 5);
Print(a, 5);
//降序排列数组
OrderArr(a, compare, 5, -1);
Print(a, 5);
}