将比较函数写入 qsort 以按指定字段对结构数组进行排序?

问题描述

我有以下结构:

struct Variant{
    char name[50];
    int age;
    long long int temporal_aura;
    char timeline[50];
    char status;
};

我将有一个结构数组,我想按上述任何字段(名称、年龄、temporal_aura、时间线、状态)对其进行排序。用于对数组进行排序的字段将由用户提供。例如:

void sort_struct(Variant **variants,int n,char *field){
    if(!strcmp(field,"name"))
        qsort(variants,n,sizeof(Variant),compare);

    if(!strcmp(field,"age"))
        qsort(variants,"temporal_aura"))
        qsort(variants,"timeline"))
        qsort(variants,"status"))
        qsort(variants,compare);
}

我的问题是:我是否必须为结构的每个成员编写一个比较函数?有没有办法优化这个代码比较函数

解决方法

我是否必须为结构的每个成员编写一个比较函数?

是的。
(除非您想要一个肮脏的“在全局变量中传递信息”解决方案)。

研究 qsort_r() 以寻找 qsort() 替代方案。


顺便说一句,我本来希望 qsort(variants,n,sizeof(Variant*),compare);(注意:*)或更好的 qsort(variants,sizeof *variants,compare);