Qsort的内部实施

Anu*_*wal 3 c qsort

qsort声明为

void qsort (void* base, size_t num, size_t size,
            int (*compar)(const void*,const void*));
Run Code Online (Sandbox Code Playgroud)

我想知道qsort如何实现反射属性.我的意思是它如何调用我们传递的名字的函数?

Fil*_*ves 19

qsort接收一个指向函数接收两个指针并返回的指针,int就是这样.调用此指针compar.所有qsort需要做的就是调用这个函数是这样的:

(*compar)(base+i, base+j);
Run Code Online (Sandbox Code Playgroud)

在哪里ij是抵消base.这真的很简单.您可以在K&R第二版,第5.11节,第120页中看到可能的实现:

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);
}
Run Code Online (Sandbox Code Playgroud)

  • 你能解释为什么有`int left,int right`而不是`size_t array_size,size_t elm_size`? (3认同)