#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);
}
我很困惑這個部分:強制轉換爲qsort函數指針
return strcmp(* (char * const *) p1, * (char * const *) p2);
他們爲什麼這樣做呢?爲什麼他們不這樣做:(const char**)
或(const char * const*)
?如果我們取消引用(const char**)
一次,我們不會得到一個指向const char的指針嗎?解引用第二個,我們不會得到一個指向const char的const指針。這兩者似乎都是strcmp()
所要求的:兩位指向常量字符的指針。手冊頁似乎給了我們const指針指向非const的東西,這似乎不是strcmp()
的聲明所要求的。即使合法,給一個函數提供一些不符合其參數的東西似乎也不是一個好主意。我錯過了什麼嗎?
最後,爲什麼不以下產生至少一個錯誤警告:
auto const char * const ptr3 = *(const char **) ptr1; //where ptr1 is
of the form int foo(const void * ptr).
提領ptr1
一次給了我們一個指向一個const char,但本身不是常量。但是,ptr3
是常量。那爲什麼編譯器不生成警告?我是否錯過了一些東西,或者有什麼理由不應該產生警告?你的問題的
忘記'auto'是C中的關鍵字 - 或者不使用它。 C++ 11爲它定義了一個用途,但在C99中它是噪聲。 –