溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

C++變量判定的螺旋法則是什么

發(fā)布時(shí)間:2021-11-24 10:39:28 來(lái)源:億速云 閱讀:131 作者:iii 欄目:編程語(yǔ)言

本篇內(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í)!

向AI問(wèn)一下細(xì)節(jié)

免責(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)容。

c++
AI