這是問題所在。我寫了這個函數來返回一個對成員向量的i元素的引用,所以這個元素可以被編輯。下面是代碼:如何編寫一個返回對成員對象引用的const訪問器,以便它可以被編輯?
Letter& Literal::get (int i) const {
return lit_m.at (i); //Vector of Letter objects
}
但G ++不會讓我這個元素賦值給一個非const引用:
g++ -o literal.o -c literal.cpp
literal.cpp: In member function ‘Letter& Literal::get(int) const’:
literal.cpp:34: error: invalid initialization of reference of type ‘Letter&’ from expression of type ‘const Letter’
怎麼可能解決呢?我的想法是建立一個像vector的at()函數那樣的函數,所以它會是const的,因爲它不會編輯對象本身,但是它應該讓我編輯返回的對象......可能嗎?
解決:我只是重載函數:),所以聲明一個const和一個非const版本。我擔心const和non-const重載是不允許的,但是我看到const改變了參數列表,使得它成爲可能。
其實你已經給他解決方案。只要指針永遠不會爲NULL,您可以對其進行解引用。 – CashCow 2010-10-20 15:52:37
我不確定它是否有效,因爲我在考慮它是否是一個const方法,它可能實際上會返回'Letter * const'或'const Letter *',而在第二種情況下,他會處於相同的狀態像以前一樣。 – Anthony 2010-10-20 15:54:17