Pointer cast for use with qsort

前端 未结 1 1595
耶瑟儿~
耶瑟儿~ 2020-12-19 11:20

This code snippet hand copied from a book I am reading:

/* scmp: string compare of *p1 and *p2 */
int scmp(const void *p1, const void *p2)
{
        char *v1         


        
相关标签:
1条回答
  • 2020-12-19 12:10

    qsort passes to the comparing function a pointer to the elements it has to compare; since in C there are no templates, this pointer is just brutally cast to a const void * (void * in C just means "this is some kind of pointer", and to do something on it you must cast it back to its actual type).

    Now, if you are sorting an array of strings, each element you have to compare is a char *; but qsort passes to the comparison function a pointer to each element, so what your scmp receives is actually a char ** (a pointer to a pointer to the first character of the string), casted to a const void * because the signature of the comparison function says so.

    So, to get your char *, you have first to convert the parameters to their actual type (char **), and then dereference this pointer to get the actual char * you want to compare.

    (although, it would be more correct from a const-correctness point of view to cast to const char **)

    0 讨论(0)
提交回复
热议问题