Qsort比较功能

时间:2014-08-17 01:13:02

标签: c++ compare qsort

void qsort (void* base, size_t num, size_t size,
    int (*compare)(const void*,const void*));

当compare函数的类型为int时,为什么qsort函数需要一个用于比较的int *返回类型?

int compare (const void * a, const void * b)
{
    if ( *(MyType*)a <  *(MyType*)b ) return -1;
    if ( *(MyType*)a == *(MyType*)b ) return 0;
    if ( *(MyType*)a >  *(MyType*)b ) return 1;
}

有人可以解释一下,我的程序因此而无法编译。谢谢! 从此来源获取的代码: http://www.cplusplus.com/reference/cstdlib/qsort/

1 个答案:

答案 0 :(得分:3)

它没有返回int *,而是返回intcompare函数指针。您在那里看到的*将其定义为函数指针。 (注意*compare周围的括号。)

cdecl解析int (*compare)(const void*,const void*))

  

将compare作为指向函数的指针(指向const void的指针,指向const void的指针)返回int

如果它是指向返回int *的函数的指针:

,那么这将是参数声明
int * (*compare)(const void*,const void*))

如果你的代码没有编译,那么它是出于其他原因。如果您想了解有关编译器错误的更具体建议,请考虑将错误消息添加到您的问题(或创建新问题)。