我有一个struct dir_item
的数组,我想用qsort
对它进行排序。使用下面的代码,我得到一个Segmentation Fault 11
。
我想知道:
- 如何解决这个问题?
- 为什么我首先有这个问题
struct dir_item
{
char name[NAME_MAX];
int is_dir;
};
struct app_state
{
char cwd[PATH_MAX];
struct dir_item *dir_entries;
int dir_entries_total;
int user_highlight;
int user_key_pressed;
};
int compare(const void *d1, const void *d2)
{
return (strcmp((*(struct dir_item **)d1)->name,
(*(struct dir_item **)d2)->name)); // I THINK THE ISSUE IS HERE, BUT NOT SURE WHY
}
qsort(dir_entries, sizeof(dir_entries), sizeof(struct dir_item), compare);
我已经尝试了这个版本,但没有排序(但没有得到错误)
int compare(const void *d1, const void *d2)
{
const struct dir_item *a = (struct dir_item *)d1;
const struct dir_item *b = (struct dir_item *)d2;
return strcmp(a->name, b->name);
}
您有太多的*
,只需将d1
和d2
转换为struct dir_item*
并取消引用:
int compare(const void *d1, const void *d2)
{
return (strcmp(((struct dir_item *)d1)->name,
((struct dir_item *)d2)->name));
}
演示