C語言中的聲明器,聲明器就是標識符以及與它組合在一塊兒的任何指針、函數括號、數組下標。數組
函數的返回值不能是一個函數,但容許是一個函數指針。安全
函數的返回值不能是一個數組,但能夠是一個指針,或者指向數組的指針。函數
數組裏面不能有函數,但容許數組裏面還有數組。測試
位段的類型必須是int,unsigned int或者signed int,只有在這個地方,int類型數據須要區分三種形態,int,signed int,unsigned int。spa
p61:有些C語言書籍聲稱「在調用函數,參數按照從右到左的次序壓到堆棧裏。」這個說法過於簡單了,若是你有一本這樣的書,請把這一頁燒掉。指針
參數在傳遞時首先儘量地存放到寄存器中(追求速度)。注意,int型變量i跟只包含一個int型成員的結構變量S在參數傳遞時的方式可能徹底不一樣。一個int型參數通常會被傳遞到寄存中,而結構參數則極可能被傳遞到堆棧中,第二點須要注意的是,在結構中放置數組,能夠實現數組的賦值。調試
struct s_tag{ int a[100];};blog
struct s_tag orange,lime;編譯器
若是如今我賦值給orange裏面的數組1-100的數據,我能夠直接lime=orange;這樣,lime結構中的數組就被直接賦值了,而傳統的數組是不容許整個拷貝的。io
在結構中,每一個成員依次存儲,而在聯合(union)中,全部的成員都從偏移地址零開始存儲。這樣,每一個成員的位置都重疊在一塊兒,在某一時刻,只有一個成員正真存儲於該地址。若是存儲數據時是一種類型,但在提取該數據時卻成了另外一種類型,這顯然存在着明顯的類型不安全性,可是能夠節約空間。
enum枚舉,在缺省狀況下整形值從0開始,而後依次增長,若是想打破依次增長的規律,能夠:
enum sizes {a=2,b,c=5,d};這樣a=2,b=3,c=5,d=6。define定義的名字在編譯時就丟棄了,而枚舉名字則一般一直在調試器中可見。還有,枚舉類型在C語言中是常量,能夠用枚舉的變量定義數組的維數足以證實這一點(並且排除了VLA這種狀況,使用不支持c99的編譯器測試的)。
關於這裏的C,也就是第三條,書上描述不夠完備,好比const int a; int const a;是同樣的,因此上面C條款應該改爲,若是const或volatile的前面或者後面緊跟類型說明符。。。。後面保持同樣。
如今來分析一下這個聲明:
char * const *(*test)();
首先找到標識符,而後看優先級和結合性。
test是一個指針,這個指向一個函數,這個函數的參數爲空,函數的返回值爲一個指針,這個指針指向只讀的指向char類型的指針。可能最後那裏有點拗口,最後那句表示這個指針指向一個char *const的數據類型,其中const是修飾左邊的星號的,表示這是一個指針常量(指針是常量,準確說是指針是隻讀變量),那麼連起來就是最後函數返回一個指針,這個指針指向一個指向char類型的只讀(const)指針。