C++聲明語法方法解讀
在C++編程語言中,有很多功能的實現(xiàn)方法與其他語言有很多不同之處,尤其是和C語言相比,它的應用方法更加靈活,方便。在這里我們就為大家詳細介紹了有關(guān)C++聲明語法的相關(guān)方法。
一個聲明為每個聲明子都聲明一個實體(entity),同時為那個實體給出一個名字,并且隱含的給出存儲類,類型,和由說明符給出的其它特性。說明符和聲明子一起決定了名字是否是一個對象,數(shù)組,指針,引用或函數(shù)。例如,
聲明x為一個整型指針,f為一個函數(shù)返回一個整型。正是聲明子*x和f()使類型x和f產(chǎn)生區(qū)別。
- int *x, f();
- declarator: [ * [ const ] | & ]... direct-declarator
- direct-declarator: declarator-id | ( declarator ) |
- direct-declarator ( parameter-declaration-list ) |
- direct-declarator [ constant-expression ]
- A declarator-id is an identifier, possibly qualified:
- declarator-id: [ nested-name-specifier ] identifier
- nested-name-specifier: { class-or-namespace-name ::}...
如果聲明子是一個僅包含一個declarator-id的直接-聲明子,那么這說明這個標識符具有decl-specifiers隱含的屬性,而沒有進一步的修飾。例如,在下面的C++聲明語法中
int n;
聲明子是n,這是一個只包含direct-declarator的declarator-id,因此根據(jù)含義,n的類型為整型。
如果聲明子為其它形式,那么你可以按照下面的方法確定標識符的類型:首先,假設T為decl-specifiers隱含的類型,忽略friend或static等非類型屬性,同時假設D為聲明子。然后重復下面的步驟直到推導出D為一個declarator-id,此時T正是你所尋找的類型:#t#
1. 如果D形如(D1),那么用D1替換D。
2. 如果D形如* D1 或 * const D1,那么根據(jù)是否有const,用“指針,它指向T”或者“常量指針,它指向T”替換T,然后用D1替換D。
3. 如果D形如D1(參數(shù)-聲明-列表),那么用參數(shù)由參數(shù)-聲明-列表定義的、“返回T的函數(shù)”替換T,然后用D1替換D。
4. 如果D形如D1[常量-表達式],那么用元素個數(shù)由常量-表達式給出的“T數(shù)組”替換T,然后然后用D1替換D。
5. ***,如果聲明子形如&D,那么用“T引用”替換T,然后用D1替換D。
作為一個示例,考慮下面的C++聲明語法
int *f();
首先,T和D分別為int和*f(),因此D形如*D1,其中D1為f()。
你可能認為D可以形如D1() 或者 *D1。然而,如果D形如D1(),那么D1將不得不為*f,D1將是一個direct-declarator(因為本節(jié)開始處的語法注1規(guī)定只有direct-declarator前面是())。但是如果我們看看direct-declarator的定義注2,很明顯它不能包含*。因此,D只能是*f(),它形如*D1,其中D為f()。
既然我們已經(jīng)確定D1為f(),那么我們知道必須用“指針,它指向T”替換T,即“指針,指向整型”,同時用f()替換D。
至此我們還沒有解析D為declarator-id,因此我們必須重復該過程。此時,D1只能是f,因此我們用“返回T的函數(shù)”替換T,它是一個“返回整型指針不帶參數(shù)的函數(shù)”,然后用f替換D。
此時,D為declarator-id,因此推導結(jié)束。我們已經(jīng)確定聲明
int *f();
聲明f的類型為“不帶參數(shù)返回整型指針的函數(shù)”。另一個例子,聲明
int* p, q;
具有兩個聲明子,*p和q。對于每個聲明子,T都是int。對于***個聲明子,D是*p,因此T變成“指針,它指向整型,”而D為p。聲明p類型為“指針,它指向整型”。
我們單獨分析第二個聲明子,T還是int,D是q。很明顯聲明q為整型。
***,讓我們分析§10.1.2/173中那個奇怪的例子:
double (*get_analysis_ptr())(const vector<Student_info>&);
分析C++聲明語法過程可以分為下面五個步驟
1. T: double D: (*get_analysis_ptr())(const vector<Student_info>&)
2. T: 返回double帶有 const vector<Student_info>& 參數(shù)的函數(shù) D: (*get_analysis_ptr())
3. T: function returning double... (如前所示) D: *get_analysis_ptr()
4. T: 指針,它指向一個返回double...的函數(shù) D: get_analysis_ptr()
5. T: 一個函數(shù),返回一個函數(shù)指針,它指向一個返回double...的函數(shù) D: get_analysis_ptr
get_analysis_ptr是一個函數(shù),它返回一個函數(shù)指針,它指向一個返回double,帶有const vector<Student_info>&參數(shù)的函數(shù)。我們將如何展開const vector<Student_info>&作為一個練習。幸運的是,C++聲明語法如此令人迷惑;它們中的大多數(shù)看起來
declarator: declarator-id ( parameter-declaration-list )
到目前為止,常見情況中最難的是返回函數(shù)指針的函數(shù)。


2010-01-21 09:34:57
2010-01-25 11:21:01
2010-02-05 14:12:46
2010-02-05 17:58:32




