3 回答

TA貢獻(xiàn)1906條經(jīng)驗(yàn) 獲得超10個(gè)贊
const
在函數(shù)聲明之后用關(guān)鍵字表示的“const函數(shù)” 使得此類函數(shù)的編譯器錯(cuò)誤更改了類的成員變量。但是,在函數(shù)內(nèi)部讀取類變量是可以的,但是在函數(shù)內(nèi)部寫入會(huì)產(chǎn)生編譯器錯(cuò)誤。
考慮這種“const函數(shù)”的另一種方法是將類函數(shù)視為采用隱式this
指針的普通函數(shù)。所以一個(gè)方法int Foo::Bar(int random_arg)
(最后沒有const)會(huì)產(chǎn)生一個(gè)類似的函數(shù)int Foo_Bar(Foo* this, int random_arg)
,并且調(diào)用Foo f; f.Bar(4)
會(huì)在內(nèi)部對(duì)應(yīng)類似的東西Foo f; Foo_Bar(&f, 4)
?,F(xiàn)在,在end(int Foo::Bar(int random_arg) const
)處添加const 可以理解為帶有const this指針的聲明:int Foo_Bar(const Foo* this, int random_arg)
。由于this
在這種情況下的類型是const,因此不可能修改成員變量。
可以放寬不允許函數(shù)寫入類的任何變量的“const函數(shù)”限制。為了允許某些變量可寫,即使函數(shù)被標(biāo)記為“const函數(shù)”,這些類變量也會(huì)用關(guān)鍵字標(biāo)記mutable
。因此,如果一個(gè)類變量被標(biāo)記為可變,并且“const函數(shù)”寫入該變量,那么代碼將干凈地編譯并且變量可以更改。(C ++ 11)
像往常一樣,在處理const
關(guān)鍵字時(shí),在C ++語句中更改const關(guān)鍵字的位置具有完全不同的含義。上述用法const
僅適用于在const
括號(hào)后添加到函數(shù)聲明的末尾時(shí)。
const
在C ++中是一個(gè)高度過度使用的限定符:語法和順序通常與指針結(jié)合使用并不簡(jiǎn)單。一些關(guān)于const
正確性和const
關(guān)鍵字的讀數(shù):

TA貢獻(xiàn)1863條經(jīng)驗(yàn) 獲得超2個(gè)贊
考慮兩個(gè)類類型變量:
class Boo { ... };
Boo b0; // mutable object
const Boo b1; // non-mutable object
現(xiàn)在,您可以調(diào)用on的任何成員函數(shù),但只能調(diào)用成員函數(shù)。Boob0constb1
- 3 回答
- 0 關(guān)注
- 848 瀏覽
添加回答
舉報(bào)