C语言的高级特性,关于指针的用法我想是不是应该认真了解下哦!

指针是C语言的灵魂。

函数指针定义形式

定义形式:
类型名 (* 指针变量名)(参数类型1,参数类型2,…);
例如:

1
int (*pf)(int,char);

使用方法

可以用一个原型匹配的函数的名字给一个函数指针赋值。
要通过函数指针调用它所指向的函数,写法为:
函数指针名(实参表);

实例代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
#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数组按照个位数从小到大进行排序。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#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;
}

运行结果:

1
10 11 123 4 8

完成coursera里面的课程设计,我想这既是机遇又是挑战