首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在qsort()中使用比较函数时分割错误11

在qsort()中使用比较函数时分割错误11
EN

Stack Overflow用户
提问于 2022-05-25 20:37:59
回答 1查看 40关注 0票数 0

我有一个struct dir_item数组,我想使用qsort对它进行排序。使用下面的代码,我得到了一个Segmentation Fault 11

我想知道:

  • 如何解决这个问题?
  • 为什么我一开始就有这个问题
代码语言:javascript
复制
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);

我尝试过这个版本,但是没有排序(但没有得到错误)。

代码语言:javascript
复制
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);
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-05-25 20:52:27

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

代码语言:javascript
复制
int compare(const void *d1, const void *d2)
{
    return (strcmp(((struct dir_item *)d1)->name,
                   ((struct dir_item *)d2)->name));
}

演示

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72383891

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档