您好,登錄后才能下訂單哦!
本篇內(nèi)容主要講解“C++變量判定的螺旋法則是什么”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“C++變量判定的螺旋法則是什么”吧!
前言
C++ 中一個(gè)標(biāo)識(shí)符配合著各種修飾界定符,使得標(biāo)識(shí)符的本意不那么直觀一眼就能看出,甚至需要仔細(xì)分析,才能知道該標(biāo)識(shí)符的具體你含義。
比如:
void (*signal(int, void (*fp)(int)))(int);
其中 signal 是什么?
螺旋法則
對(duì)于如何進(jìn)行變量的辯識(shí),有個(gè)非官方的 “順時(shí)針/螺旋法則(Clockwise/Spiral Rule)” 可用來(lái)幫助辯識(shí)。
該法則的內(nèi)容,簡(jiǎn)單來(lái)說(shuō),為了搞清楚一個(gè)未知標(biāo)識(shí)符的含義,我們可以:
1、從我們需要判定的標(biāo)識(shí)符開(kāi)始,順時(shí)針畫(huà)圈,遇到如下符號(hào)時(shí),用對(duì)應(yīng)的語(yǔ)義替換:
[x] 或 [] => 容量為 x 的數(shù)組或數(shù)組 (type1,type2...) => 接收 type1、type2... 的函數(shù),返回值為(待定) * => 指向(類(lèi)型待定)的指針
2、重復(fù)上面的步驟直到語(yǔ)句中所有符號(hào)都被遍歷過(guò)。
3、始終優(yōu)先解析括號(hào)括起來(lái)的部分。
實(shí)地演練
一個(gè)簡(jiǎn)單的示例
先從一個(gè)簡(jiǎn)單的開(kāi)始,判定如下語(yǔ)句中 str 的含義:
+-------+ | +-+ | | ^ | | char *str[10]; ^ ^ | | | +---+ | +-----------+
根據(jù)螺旋法則,如上面線(xiàn)圖標(biāo)識(shí)所示,
從 str 這個(gè)需要被判定的對(duì)象出發(fā)。 螺旋路徑上第一次遇到的是 [ 左方括號(hào),由此我們知道,str 是一個(gè)尺寸為 10 的數(shù)組。 繼續(xù)旋轉(zhuǎn),遇到 *,所以 str 是一個(gè)尺寸為 10 的數(shù)組,數(shù)組元素為指針。 繼續(xù),遇到 ; 標(biāo)識(shí)語(yǔ)句的結(jié)束。 再繼續(xù),遇到 char,所以 str 是一個(gè)尺寸為 10 的數(shù)組,數(shù)組元素為指向 char 類(lèi)型的指針。
進(jìn)階
回到文章開(kāi)頭那個(gè)語(yǔ)句,來(lái)判定其中 signal 的含義。
+-----------------------------+ | +---+ | | +---+ |+-+| | | ^ | |^ || | void (*signal(int, void (*fp)(int)))(int); ^ ^ | ^ ^ || | | +------+ | +--+| | | +--------+ | +----------------------------------+
由螺旋法則畫(huà)出如上的線(xiàn)圖,進(jìn)而可分析:
從要判定的 signal 出發(fā)首次遇到 ( 左括號(hào),表示 signal 是一個(gè)函數(shù),入?yún)?int 和 ...
此處需要需要進(jìn)一步運(yùn)用螺旋法則先確定 fp 的含義,才能進(jìn)而確認(rèn) signal 這個(gè)函數(shù)的完整入?yún)?。所以?fp 了發(fā)進(jìn)行一次子螺旋。
因?yàn)樾枰獌?yōu)先解析括號(hào)括起來(lái)的部分,所以轉(zhuǎn)一圈回來(lái)首次遇到的是 *,由此 fp 是一個(gè)指針。
繼續(xù)解析 fp,遇到 (,所以 fp 是一個(gè)指向函數(shù)的指針,這個(gè)函數(shù)接收一個(gè) int 類(lèi)型的入?yún)ⅰ?/p>
繼續(xù)下去,遇到 void,所以 fp 是一個(gè)指向函數(shù)的指針,這個(gè)函數(shù)接收一個(gè) int 類(lèi)型的入?yún)⒉⑶曳祷刂禐榭铡?/p>
至此完成了 fp 的解析,可以知道 signal 的類(lèi)型為:
是一個(gè)函數(shù),入?yún)椋? 一個(gè) int 類(lèi)型 一個(gè)指向函數(shù)的指針,這個(gè)函數(shù)接收一個(gè) int 類(lèi)型的入?yún)⒉⑶曳祷刂禐榭?/p>
路徑跑到 signal 的螺旋中,遇到 *(緊鄰 signal 左邊),所以 signal 是
一個(gè)函數(shù),入?yún)椋? 一個(gè) int 類(lèi)型 一個(gè)指向函數(shù)的指針,這個(gè)函數(shù)接收一個(gè) int 類(lèi)型的入?yún)⒉⑶曳祷刂禐榭? 返回值為指針
再繼續(xù),遇到 (,接上面,返回值為指向另一函數(shù)的指針,被指向的這個(gè)函數(shù)接收一個(gè) int 入?yún)ⅰ?/p>
最后,遇到 void,signal 返回值指向的這個(gè)函數(shù)的返回值為空。
最后捋一下 signal 的完整類(lèi)型為:接收一個(gè) int,一個(gè)指向接收一個(gè) int 并且返回值為空的函數(shù)的指針,這兩個(gè)參數(shù)的函數(shù),并且返回值為指向一個(gè)接收 int 型返回為空的函數(shù)...Orz。
成員函數(shù)的判定
螺旋施法沒(méi)有給出在 const 參與的情況下的判定,不過(guò)因?yàn)?const 默認(rèn)修飾緊鄰其左邊的元素,如果右邊無(wú)元素,則修飾左邊的元素。因此只需要將 const 和它修飾的元素作為整體來(lái)看,就還是可以使用螺旋法則的。
考察如下語(yǔ)句:
const int*const Method3(const int*const&) const;
當(dāng)函數(shù)后面緊跟一個(gè) const 時(shí),表示該成員函數(shù)的作用域內(nèi) *this 是常量,即無(wú)法在該函數(shù)體內(nèi)對(duì)所類(lèi)的實(shí)體進(jìn)行修改。
下面對(duì)上面的語(yǔ)句進(jìn)行分析:
從 Method3 出發(fā),遇到 (,所以 Method3 是一個(gè)函數(shù),接收一個(gè)引用作為入?yún)?const int*const& 部分。 該引用的類(lèi)型是 const int*const,指向整形常量的常量指針。 繼續(xù)遇到 *const,所以函數(shù)的返回值為常量指針。指針指向的類(lèi)型為 const int 整形常量。 函數(shù)末尾的 const 如前所述,標(biāo)識(shí)函數(shù)體內(nèi)不修改實(shí)例。
到此,相信大家對(duì)“C++變量判定的螺旋法則是什么”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢(xún),關(guān)注我們,繼續(xù)學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。