- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
所以我在下面声明了 main 函数,用户必须在第一次执行程序时从命令行向其传递参数。然后,它采用 *argv[]
字符串输入数组并使用 stdlib.h
的 qsort 函数对它们进行排序,之后它最终打印出所有元素,除了输入数组中的文件名;
int main(int argc,char *argv[]){
qsort(argv,args,sizeof(*argv),comp_func);
for(int U=1;U<argc;U++)printf("%s\n",argv[U]);
}
传递给qsort
的comp_func
函数如下所示:
int comp_func(char*a,char*b){
return strcmp(*(char **)a,*(char **)b);
}
我想知道的是这里发生了什么?我很高兴 qsort
将数组的每个 2 长度排列发送到给定的比较器函数,在这种情况下,这两个都是字符串,因为 argv
是一个数组字符串。但是,我不明白这里发生了什么:
strcmp(*(char **)a,*(char **)b)
*(char **)a
在做什么?它只是创建一个任意的 char[]
指针数组,该指针指向长度为 1 的任意字符串,然后将其第一个值分配给 a
,然后是最终取消引用,最终返回字符串 a
?如果是这样,那为什么普通的 a
不起作用?另外,有趣的是,如果我 printf
只是普通的 a
,它会输出一串随机字符,类似于 ??O_?
。但是,当我改为 printf *(char **)a
时,我得到了实际的字符串输入。这是为什么?我是 C
的初学者,所以如果我有任何问题,请多多包涵。
最佳答案
qsort()
需要一个连续的对象数组作为第一个参数 base
。现在,argv
是一个 const char *
指针数组,所以
qsort(argv, args, sizeof(*argv), comp_func);
表示,对指针数组进行排序,其中 sizeof(*argv)
是 const char *
的大小。
传递给 comp_func()
的是两个对象从基指针偏移的地址,即 argv
中 char 指针的地址。要返回包含参数字符串的实际字符串数组/指针,我们需要取消引用它。也就是说,参数字符串实际上位于 *a
和 *b
。
签名仍然完全错误,应该会到处抛出编译器警告。 comp_func()
实际上需要两个 const void *
:
int
comp_func(const void *a,const void *b) {
return strcmp(*(const char **)a,*(const char **)b);
}
强制转换是必要的,因为 *a
不是具有 const void *
的有效类型并且 strcmp()
需要 const char *
,也是。
关于c - 将数组传递给 "qsort"是如何工作的?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38784890/
我正在尝试对这个字符串列表进行排序:["a", "z", "b"]。所以答案应该是 ["a", "b", "z"]。但是,当我尝试使用 C 的 qsort() 时,没有任何 Action !我做错了什
我尝试使用 qsort 创建一些基本代码来对字符串数组进行排序,但根据 gdb,它在 qsort 中崩溃了: #include #include static int pcmp(const voi
我想使用 qsort(...) 对 2D int 数组进行排序,但我的比较函数似乎是错误的。 qsort的参数如下: qsort(void *base, size_t nitems, size_t s
我一直在寻找一种方法来对 C 中的数组子集进行排序,而无需将元素移动到临时数组并将它们复制回来。我可能对 qsort 理解不好,但我认为下面的代码应该可以工作: qsort(&my_struct_ar
我正在使用标准 c 库的 qsort 函数对组织在数组中的数百万个结构进行排序。我试图通过创建具有相同长度的结构指针数组来优化性能。与我的预期相反,第二个变体的执行时间较慢: qsort 结构数组:1
我成功地对结构数组进行了排序,其中每个结构仅包含一个 char 字符串。然而,我的问题是,对于大约的结构数组。 900,000 个元素,qsort 比我预期的要长很多(qsort 需要大约 2 分钟来
这个问题在这里已经有了答案: How to qsort an array of pointers to char in C? (8 个答案) 关闭 5 年前。 我尝试使用 qsort 对字符串数组进
我正在尝试重构一个当前是独立 C 程序的实用程序,以便我可以创建一个可重用的库。它包括根据全局数组中的相应值对数组进行排序的步骤。 // Global lookup table double *rat
我尝试对下面的一个struct进行排序,目的是对它们的错误率进行排序,同时保留sid和did的信息。虽然没有编译错误,但我在运行时遇到段错误。我想知道出了什么问题.... #include #inc
我正在尝试创建一个函数模板,该模板接收一个数组作为输入并对它进行排序。为了对其进行排序,我想我可以使用C++标准库的头文件qsort()中包含的cstdlib函数。 qsort()函数需要将比较器函数
#include #include #include int sortstring(const void *str1, const void *str2) { const char *r
我正在尝试对一个名为 results 的 struct run 数组进行排序,但是当我打印该数组时,没有任何排序。看看这个: struct run { char name[20], weekday
我尝试对下面的一个struct进行排序,目的是对它们的错误率进行排序,同时保留sid和did的信息。虽然没有编译错误,但我在运行时遇到段错误。我想知道出了什么问题.... #include #inc
考虑一个结构指针数组。以下代码取自您可能会找到的示例 here 。我想要为这两排铸件进行移植。我对这种“双重类型转换”不熟悉。 int myptrstructcmp(const void *p1, c
为什么我们在使用qsort()时,int(*compar)(const void*,const void*)没有添加任何参数,却也能完成它们的功能呢? 比如这样: double vals[NUM];
void qsort ( void* base, size_t num, size_t size, int (*compar)(const void*,const vo
嗨,我是学习 C 编程语言的新手,很难理解这个问题。我想对指向 struct[person] 指针数组的双指针进行排序。我需要根据多个标准对结构指针进行排序。 (年龄按升序排列,姓名和高度均按降序排列
我想对数组的特定列进行排序,但必须相应地移动其他元素例如 UNSORTED ARRAY 40 2 30 6 20 1 REQUIRED SORTED ARRAY 20 1 30 6 40 2 如果不能
假设我们有一个结构: struct product { char name[30]; float price; }; 我想首先使用 qsort 按价格对其进行排序,如果价
这个问题已经有答案了: What sorting algorithm does qsort use? (3 个回答) 已关闭 9 年前。 该功能是否qsort()在stdlib.h实际上使用快速排序算
我是一名优秀的程序员,十分优秀!