在qsort()中使用比较函数时出现分段故障11

  • 本文关键字:分段 故障 函数 比较 qsort c
  • 更新时间 :
  • 英文 :


我有一个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);
}

您有太多的*,只需将d1d2转换为struct dir_item*并取消引用:

int compare(const void *d1, const void *d2)
{
return (strcmp(((struct dir_item *)d1)->name,
((struct dir_item *)d2)->name));
}

演示

最新更新