在学习qsort函数中,我本人对其函数的理解,首先,对于该函数
void qsort(void* base,
size_t num,
size_t size,
int (*cmp)(const void*, const void*)
);
这是该函数的主体,下面是我本人对该函数的理解
void qsort(void* base, //这是一个指针,它指向的对象是你想要排序的数组的第一个元素。
size_t num, //这里指的是你排序的元素的个数。
size_t size, //这里指向排序的其中一个元素的大小。
int (*cmp)(const void*, const void*)//这是一个函数指针,指向一个函数,但是这个函数需要你自主进行创建,目的是能实现数组中俩个元素的比较。
);
举一个例子
int cmp_int(const void* p1, const void* p2)
{
return (*(int*)p1 - *(int*)p2);
}
test1()
{
int arr[10] = { 9,8,7,6,5,4,3,2,1,0 };
int sz = sizeof(arr) / sizeof(arr[0]);
qsort(arr, sz, sizeof(arr[0]), *cmp_int);
}
我们要把这个arr数组的元素从小到大排序,
qsort(arr, //这里就是数组的首元素
sz, //这里便是数组元素的个数
sizeof(arr[0]), //这里便是其中一个元素的大小
*cmp_int //这里指向前面的我们前面写的一个函数。
);
int cmp_int(const void* p1, const void* p2)
{
return (*(int*)p1 - *(int*)p2); //由于我们知道我们比较的数组元素是整形,使用我们需要先对这些数据进行数据的转化。
}
希望能有帮助。