C语言的高级特性,关于指针的用法我想是不是应该认真了解下哦!
指针是C语言的灵魂。
函数指针定义形式
定义形式:
类型名 (* 指针变量名)(参数类型1,参数类型2,…);
例如:
int (*pf)(int,char);
使用方法
可以用一个原型匹配的函数的名字给一个函数指针赋值。
要通过函数指针调用它所指向的函数,写法为:
函数指针名(实参表);
实例代码
#include<stdio.h>
void PrintMin(int a,int b)
{
if(a<b)
printf("%d",a);
else
printf("%d",b);
}
int main()
{
void (* pf)(int, int);
int x = 4,y = 5;
pf = PrintMin;
pf(x,y);
return 0;
}
函数指针和qsort库函数
C语言快速排序库函数:
void qsort(void *base,int nelem,unsigned int width,int( * pfCompare)(const void *,const void *));
可以对任意类型的数组进行排序
- base:待排序数组的起始地址;
- nelem:待排序数组的元素个数;
- width:待排序数组的每个元素的大小(以字节为单位);
- pfCompare:比较函数的地址
注意:pfCompare需要自己编写
格式:int 函数名(const void * elem1,const void * elem2);
排序就是一个不断比较并交换位置的过程。
比较函数编写规则:
- 如果* elem1应该排在 * elem2前面,则函数返回值是负整数
- 如果* elem1和* elem2哪个排在前面都行,则函数返回0
- 如果* elem1应该排在 * elem2后面,则函数返回值是正整数
代码实例
调用qsort库函数,将一个unsigned int数组按照个位数从小到大进行排序。
#include<stdio.h>
#include<stdlib.h>
int MyCompare(const void * elem1,const void *elem2)
{
unsigned int * p1,* p2;
p1 = (unsigned int *)elem1;//强制类型转换,"elem1"非法
p2 = (unsigned int *)elem2;//"elem2"非法
return (*p1 % 10) - (*p2 % 10);
}
#define NUM 5
int main()
{
unsigned int an[NUM] = {8,123,11,10,4};
qsort(an,NUM,sizeof(unsigned int),MyCompare);
for(int i = 0;i < NUM;i++)
printf("%d",an[i]);
return 0;
}
运行结果:
10 11 123 4 8
完成coursera里面的课程设计