arrays - 在 qsort() 之后无法循环遍历字符串数组
问题描述
我正用这个问题把头撞在墙上。
总结一下:我需要动态地将字符串添加到数组中,对它们进行排序,然后检查另一个字符串值。
这需要在支持 C 作为脚本语言但功能有限的 SCADA 系统上工作。我有 qsort() 可用。
但是,使用我拥有的测试代码,我无法在数组上使用 qsort,并使用动态添加的值。
需要明确的是,我可以将字符串添加到数组中,效果很好。但是,当我在该数组上调用 qsort() 时,我无法再打印出索引。
这是到目前为止的代码(请客气,我对 C 语言不是很精通):
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
int cstring_cmp (const void *a, const void *b)
{
// This function is taken from an online example
const char **ia = (const char **) a;
const char **ib = (const char **) b;
return strcmp (*ia, *ib);
}
int main ()
{
//char *ArchiveKomponents[] = {"R1890L", "F1121D", "F1284Z", "A1238K"};
// If I do the above commented out, it works as intended
char ArchiveKomponents[100][20];
strcpy(ArchiveKomponents[0], "R1890L");
strcpy(ArchiveKomponents[1], "F1284Z");
size_t strLen = sizeof (ArchiveKomponents) / sizeof (char *);
printf ("Len: %zu\n", strLen);
printf ("Before [0]: %s\n", ArchiveKomponents[0]);
printf ("Before [1]: %s\n", ArchiveKomponents[1]);
qsort (ArchiveKomponents, (size_t)strLen, sizeof (char *), cstring_cmp);
printf ("After [0]: %s\n", ArchiveKomponents[0]);
printf ("After [1]: %s\n", ArchiveKomponents[1]);
// When run, the "After" prints are not even printed, the program simply halts
return 0;
}
我觉得我已经用谷歌搜索了整个互联网,以寻找如何做到这一点的答案,但没有运气。
问候
解决方案
您正在比较不正确的类型。比较函数将元素中的 4 或 8 个字符视为指向字符串的指针。取消引用此指针会触发未定义的行为,可能会导致崩溃。
请注意,单个元素的类型char[20]
不是char*
. 因此,您的比较功能可以简单地实现为:
int cstring_cmp (const void *a, const void *b)
{
return strcmp (a, b);
}
指向20 个字符的数组的指针a
和b
点。数组的地址与其第一个元素的地址相同。所以a
andb
可以用作指向链的指针char
(又名“c-strings”)。此外,void*
无需强制转换即可自动转换为任何指针类型。
qsort
调用应该是:
qsort (ArchiveKomponents, // array to be sorted
2, // number of elements in the array
sizeof ArchiveKomponents[0], // size of a single element
cstring_cmp // comparison function
);
推荐阅读
- java - java - 如何在java netbeans的表格单元格中添加一个按钮?(我正在使用拖放方法。)
- c# - 在数据库中有效地存储/更新不可预测的列表
- java - 来自第三方 API 的模拟调用和响应
- python - PyQtGraph 不会调整大小
- python - 使用 python xlrd 模块打开 Excel 文件时出现编码错误
- postgresql - 确定增加的 PostgreSQL 共享内存的来源
- react-native - Expo 中用于 React Native 的 Dialogflow API 聊天机器人
- db2 - 在一个命令中执行多个 db2 命令
- javascript - 如何编写茉莉花规范以在 jquery 中触发 on 事件
- authentication - 如果演示者和请求的主题不同,对 SAML 身份验证请求的响应应该包括哪些断言?