#include
#include
#include
int comp(const void * p_num, const void * p_num1)
{
return strcmp(*(const char * * )p_num, *(const char * * )p_num1);
}
int main(int argc, char *argv[])
{
char *strs[] = {"China", "France", "England", "America", "Russia"};
int num = 0;
qsort(strs, 5, sizeof(char), comp);
for (num = 0; num <= 4; num++)
{
printf("%s\n", strs[num]);
}
return 0;
}
/* 注意:以上程序是正确的,*/
/* 疑问:为啥用二级指针类型转换?
我的理解,char strs[]是数组指针,并里面都是地址,也是指针数组,所以strs应该为二级指针。那么strs[0]就是数组里面“China”的地址,接收它的地址应该用二级
指针,这儿函数comp里面其实是二级指针的地址const void *p_num,所以
可以用(const char **)p_num来表示数组中的字符串地址。这样理解算正确的吗?
*/
麻烦各位帮看下,另外,我这儿的comp函数中第二个参数明明写了两个*结果还是只显示一个。郁闷,另外排版的问题,我尝试缩进了,可是打出来还是
这种无缩进的样子。
因为二级指针代表的字符串,一级指针代表的是指向字符串首个字符的指针。
好比对int排序的话,用的是int *
而字符串本身就是char 了,所以是char *
我好想懂了。
printf("%s\n", strs[num]),这里就是二级指针str数组里面的一个值,也就是一级指针的地址,所以用%s,输出字符串。
我尝试在定义char *strs[]时将 * 去掉,在打印printf函数时会出现告警,提示应该用%d,咳咳,这应该就是你说的一级指针表示指向字符串首个字符的
指针吧。
但是二级指针表字符串还是有点模糊,毕竟二级指针都是指向一级的地址。能说的再详细点嘛英雄。
看着代码有问题,我试了下不能排序呢