const char ** const p6; // const pointer to pointer to const char
char * const * const p7; // const pointer to const pointer to char
const char * const * const p8; // const pointer to const pointer to const char
注:
p1是指向char類型的指針的指針;
p2是指向const char類型的指針的指針;
p3是指向char類型的const指針;
p4是指向const char類型的const指針;
p5是指向char類型的指針的const指針;
p6是指向const char類型的指針的const指針;
p7是指向char類型const指針的const指針;
p8是指向const char類型的const指針的const指針。
//------------------------------------------------------------------------
typedef的妙用
typedef給你一種方式來克服“*只適合于變量而不適合于類型”的弊端。你可以如下使用typedef:
typedef char * PCHAR;
PCHAR p,q;
這里的p和q都被聲明為指針。(如果不使用typedef,q將被聲明為一個char變量,這跟我們的第一眼感覺不太一致。┫旅嬗幸恍┦褂胻ypedef的聲明,并且給出了解釋:
typedef char * a; // a is a pointer to a char
typedef a b(); // b is a function that returns
// a pointer to a char
typedef b *c; // c is a pointer to a function
// that returns a pointer to a char
typedef c d(); // d is a function returning
// a pointer to a function
// that returns a pointer to a char
typedef d *e; // e is a pointer to a function
// returning a pointer to a
// function that returns a
// pointer to a char
e var[10]; // var is an array of 10 pointers to
// functions returning pointers to
// functions returning pointers to chars.
typedef經常用在一個結構聲明之前,如下。這樣,當創(chuàng)建結構變量的時候,允許你不使用關鍵字struct(在C中,創(chuàng)建結構變量時要求使用struct關鍵字,如struct tagPOINT a;而在C++中,struct可以忽略,如tagPOINT b)。
typedef struct tagPOINT
{
int x;
int y;
}POINT;
POINT p; /* Valid C code */
//------------------------------------------------------------------------
函數指針
函數指針可能是最容易引起理解上的困惑的聲明。函數指針在DOS時代寫TSR程序時用得最多;在Win32和X-Windows時代,他們被用在需要回調函數的場合。當然,還有其它很多地方需要用到函數指針:虛函數表,STL中的一些模板,Win NT/2K/XP系統(tǒng)服務等。讓我們來看一個函數指針的簡單例子:
int (*p)(char);
這里p被聲明為一個函數指針,這個函數帶一個char類型的參數,并且有一個int類型的返回值。另外,帶有兩個float類型參數、返回值是char類型的指針的指針的函數指針可以聲明如下:
char ** (*p)(float, float);
那么,帶兩個char類型的const指針參數、無返回值的函數指針又該如何聲明呢?參考如下:
void * (*a[5])(char * const, char * const);
“右左法則”[重要。!]
The right-left rule: Start reading the declaration from the innermost parentheses, go right, and then go left. When you
encounter parentheses, the direction should be reversed. Once everything in the parentheses has been parsed, jump out of it.
Continue till the whole declaration has been parsed.
這是一個簡單的法則,但能讓你準確理解所有的聲明。這個法則運用如下:從最內部的括號開始閱讀聲明,向右看,然后向左看。當你碰到一個括號時就調轉閱讀的方向。括號內的所有內容都分析完畢就跳出括號的范圍。這樣繼續(xù),直到整個聲明都被分析完畢。對上述“右左法則”做一個小小的修正:當你第一次開始閱讀聲明的時候,你必須從變量名開始,而不是從最內部的括號。
下面結合例子來演示一下“右左法則”的使用。
int * (* (*fp1) (int) ) [10];
閱讀步驟:





