float (**def)[10]這個是什麼?

以下內容爲轉載
答案:  (1) def是一個指針, 指向的對象也是一個指針, 指向的指針最終指向的是10個float構成的數組. 
如果我們碰到複雜的類型聲明,該如何解析它?例如: char (*a[3])(int); 
a到底被聲明爲什麼東東?指針?數組?還是函數? 
分析時,從a 最接近(按運算符優先級)處開始。我們看到a最接近符號是[ ]——注意:*比[ ]的優先級低。a後既然有[ ],那麼a是數組,而且是包含3個元素的數組。 
那這個數組的每個元素是什麼類型呢?雖然數組a只含有a[0]、a[1]、a[2]三個元素,a[3]實際上已經越界,但在分析數組a的元素的類型時,我們正好需要形式上的元素a[3]。知道了a[3]的類型,就知道了a的元素的類型。 a[3]是什麼類型?是指針,因爲它的前面有*. 由此可知,數組a的元素是指針。 
光說是指針還不夠。對於指針,必須說出它指向的東東是什麼類型。它指向的東東是什麼,就看*a[3]是什麼(a[3]是指針,它指向的東東當然是*a[3])了。繼續按優先級觀察,我們看到*a[3]後面有小括號,所以可以肯定*a[3]是函數。即數組a的元素是指向函數的指針。 
指向的是什麼類型的函數?這很明顯,是入參爲int、返回值爲char的類型的函數。 
至此解析完畢。 
按上述方法,再複雜的也可以一步步解析出來。 


就像習武不是爲了打人而是爲了防身一樣,我們瞭解上述方法是爲了看懂別人寫的複雜聲明,而不是爲了在實踐中自己去構造這種複雜的東東。實在需要複雜聲明時,可以用typedef替代一部分。例如上面語句可改成兩句: 
typedef char (*FUN_PTR)(int); 
FUN_PTR a[3]; 
這樣就清晰多了。 
此外,上面的分析方法還讓我們對某些東西的本質更加清楚。比如,n維數組的本質都是一維數組。看個具體的例子: 
int a[3][5]; 
這句聲明的是一個包含3個元素的一維數組,其每個元素又是一個由5個int數構成的數組。我們不能理解爲:a是一個包含5個元素的一維數組,其每個元素又是一個由3個int數構成的數組。爲什麼?還是按上面的方法分析,這裏從略。


有的書上或網上提供"向右看,向左看"的方法, 其實缺乏通用性, 比如它不適用於對多維數組本質的分析. 而且這種方法掩蓋了本質. 本質應該是按上面所講的,根據運算符優先級逐層剝開.


轉載結束


現在我們用上面的方法來分析一下:
double *(*gh)[10];
首先gh離*最近,那麼gh肯定是一個指針,*的優先級比[]低,那麼gh是指向一個包含10個元素的數組,這個數組的內容呢就是指向double類型的指針
double (*f[10])();
還是按照上面的博主說的方法,按照優先級來說[]的優先級比*高,所以f是一個數組,他擁有10個元素,這個十個元素是函數指針,指向的函數時沒有形參,返回類型是double型的函數
int*((*b)[10]);
這裏看得出來b肯定是一個指針了,指向的是一個包含10個元素的數組,這個數組裏面存放的內容是指向int型的指針
long (*fun)(int);
函數指針
int (*(*f)(int,int))(int)
這裏面呢f是一個函數指針,他的形參是兩個int型,他的返回值也是一個函數指針,指向的是形參爲int型,返回值也爲int的函數
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章