#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <assert.h>
static int cmpstringp(const void *p1, const void *p2)
{
/* The actual arguments to this function are "pointers to
pointers to char", but strcmp(3) arguments are "pointers
to char", hence the following cast plus dereference */
return strcmp(* (char * const *) p1, * (char * const *) p2);
}
int main(int argc, char *argv[])
{
int j;
assert(argc > 1);
qsort(&argv[1], argc - 1, sizeof(argv[1]), cmpstringp);
for (j = 1; j < argc; j++)
puts(argv[j]);
exit(EXIT_SUCCESS);
}
Объркан съм с тази част:
return strcmp(* (char * const *) p1, * (char * const *) p2);
Защо направиха това? Защо НЕ направиха това: (const char**)
или (const char * const*)
? Не получаваме ли указател към const char, ако дереферираме веднъж за (const char**)
? Дереферирайки втория, не получаваме ли константен указател, който сочи към константен char. И двете изглеждат като това, което strcmp()
иска: два указателя, които сочат към const chars. Това, което man страницата изглежда ни дава константни указатели, сочещи към неконстантни неща, което не изглежда да е това, което иска декларацията на strcmp()
. Дори да е законно, не изглежда добра идея да се даде на функция нещо, което не отговаря на нейните параметри. Изпускам ли нещо?
И накрая, защо следното не генерира поне предупреждение за грешка:
auto const char * const ptr3 = *(const char **) ptr1; //where ptr1 is
of the form int foo(const void * ptr).
Дереферирането на ptr1
веднъж ни дава указател към const char, но само по себе си не е const. Въпреки това, ptr3
е const. Така че защо компилаторът не генерира предупреждение? Пропускам ли нещо или има причина да не генерира предупреждение?
auto
е ключова дума в C - или не я използвайте. C++11 е дефинирал употреба за него, но в C99 това е шум. - person Jonathan Leffler   schedule 22.10.2011