類的const和非const成員函數(shù)的重載
我們從一個例子說起,來看上一篇文章中的String類, 我們?yōu)樗峁┮粋€下標操作符([ ])以讀寫指定位置的字符(char)。
只要了解過C++的操作符重載的語法,很快就可以寫出下面這個[]操作符重載函數(shù):
char& operator[](int posion)? ? // function_1
{
return data[posion];
};
注意,這里該函數(shù)的返回值為一個引用,否則str[0] = 'c'這樣的語句就會不合法,因為str[0]將是一個左值。
那么,是否提供這樣一個function_1就足夠了呢?看下面這段代碼:
const String str= "She";
char c = str[0];? ? // 錯誤!編譯提示:error C2678: 二進制“[” : 沒有找到接受“const String”類型的左操作數(shù)的運算符(或沒有可接受的轉(zhuǎn)換)
很顯然,我們必須還要為const String提供一個const版本的opeartor[]。如下:
char& operator[](int posion) const
{
return data[posion];
}
這樣,當(dāng)使用const的String對象使用[]操作符時,便會調(diào)用該const的重載版本。
但是,這樣就OK了嘛?雖然上面的那段代碼沒有問題了,但是其中卻隱藏了一個陷阱,看如下代碼:
const String str = "She";
str[0] = 'T';
上面這段代碼可以編譯,運行通過,str變?yōu)榱?The"!而str聲明為const的!!
現(xiàn)在,你應(yīng)該知道了,對于const的該操作符重載函數(shù)其返回值也應(yīng)該是const的,否則就會出現(xiàn)可以通過其修改const對象的漏洞。修改如下:
const char& operator[](int posion) const
{
return data[posion];
}
好了,現(xiàn)在沒有問題了!
我們再回過頭來看一下,為了給String提供一個[]操作符來讀寫指定位置的字符,需要提供如下兩個函數(shù),以分別對非const String對象和const String對象提供支持:
char& operator[](int posion)
{
return data[posion];
};
const char& operator[](int posion) const
{
return data[posion];
}