void qsort(void base, size_t num, size_t size, int (*compar)(const void*p1, const void*p2))排序函数,可以排序各种类型的函数
四个参数:
void qsort(
void base,:base指向数组的第一个元素
size_t num,:base指向的数组元素的个数(待排序元素的个数)
size_t size,:base指向数组中元素的大小(单位是字节)(一个元素的大小)
int (*compar)(const void*p1, const void*p2):函数指针,指针指向的函数是用来比较数组中的两个元素的
)
应用qsort时,第四个参数int (*compar)(const void*p1, const void*p2),这个函数指针是由自己构建的。
int (*compar)(const void*p1, const void*p2),返回值是int 类型,返回值是一个整形,函数指针会根据返回值 >0 ==0 <0,三种情况进行排序,默认为升序(倒序互换p1 p2位置即可)
在这个函数指针中p1代表第一个元素,p2代表第二个元素,由于传参时传递的void*类型,而返回值是int 类型,故需要(int *)强制类型转换,再进行*解引用获取地址内容,即写成* ( int* )形式。