首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Qsort的内部实现

Qsort的内部实现
EN

Stack Overflow用户
提问于 2013-10-18 04:57:12
回答 2查看 14.2K关注 0票数 3

qsort声明为

代码语言:javascript
复制
void qsort (void* base, size_t num, size_t size,
            int (*compar)(const void*,const void*));

我想知道qsort是如何实现反射属性的。我的意思是,它如何调用我们传递了其名称的函数?

EN

回答 2

Stack Overflow用户

发布于 2013-10-18 05:03:46

qsort接收一个指向函数的指针,接收两个指针并返回int,仅此而已。这个指针被称为compar。调用此函数所需的所有qsort操作如下所示:

代码语言:javascript
复制
(*compar)(base+i, base+j);

其中ijbase的偏移量。事情真的就这么简单。你可以在K&R第二版,第5.11节,第120页看到一个可能的实现:

代码语言:javascript
复制
void qsort(void *v[], int left, int right, int (*comp)(void *, void *)) {
    int i, last;
    void swap(void *v[], int, int);

    if (left >= right)
        return;
    swap(v, left, (left + right)/2);
    last = left;
    for (i = left+1; i <= right; i++)
        if ((*comp)(v[i], v[left]) < 0) /* Here's the function call */
            swap(v, ++last, i);
    swap(v, left, last);
    qsort(v, left, last-1, comp);
    qsort(v, last+1, right, comp);
}
票数 18
EN

Stack Overflow用户

发布于 2013-10-18 05:30:10

qsort接收的是一个指向函数的指针,所以要使用该函数,它需要做的就是取消对该指针的引用。

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

https://stackoverflow.com/questions/19437135

复制
相关文章

相似问题

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