載自《C++ Primer 第四版》12.4.3節
3. 使用預設建構函式
初級 C++ 程式員常犯的一個錯誤是, 採用以下方式聲明一個用預設建構函式初始化的對象:
//oops! declares a function , not an object
Sales_item myObj();
編譯 myObj 的聲明沒有問題. 然而, 當我們試圖使用 myObj 時
Sales_item myObj(); //OK: but defines a function, not a object
if(myObj.same_isbn(Primer_3rd_ed)) //error: myObj is a function
編譯器會指出不能將成員訪問符用於一個函數! 問題在於 myObj 的定義被編譯器解釋為一個函數的聲明, 該函數不接受參數並返回一個 Sales_item 的對象 ------- 與我們的意圖大相徑庭!
使用預設建構函式定義一個對象的正確方式是去掉最後的空括弧:
//ok! difines a class object
Sales_item myObj; //隱式地調用建構函式 <plus 10.3.2>
另一方面, 下面的這段代碼也是正確的:
//ok: create an unnamed, empty Sales_item and use to initialize myObj
Sales_item myObj = Sales_item(); //顯示地調用建構函式 <plus 10.3.2>
在這裡, 我們建立並初始化一個 Sales_item 對象, 然後用它來按值初始化 myObj . 編譯器通過運行 Sales_item 的預設建構函式來按值初始化一個 Sales_item.
----------------------------------------------- 可愛的分割線 ------------------------------------------------------------
本菜鳥就剛好遇到了這個問題, 還好書中有說明呢, 不然就鬱悶了. 真是搞不懂編譯器為什麼解釋為函數的聲明, 並且是在*.cpp 中.
這個我知道答案了, 看看 <functional> 的原始碼, 利用模版類和 () , 執行相關的函數. 比如typename classA, 像 classA() 如果不是聲明為函數的話, 那這個 <functional> 庫就沒作用了.
//ok: create an unnamed, empty Sales_item and use to initialize myObj
在這裡, 我們建立並初始化一個 Sales_item 對象, 然後用它來按值初始化 myObj .
上面兩句, 我不敢苟同呢, 顯示調用建構函式和隱式調用建構函式所進行的操作是一樣的. 應該不存在 顯示調用建構函式 就是先建立對象, 再對命名物件賦值的情況?????????.
<C++ Primer Plus第五版> 316頁, 打消了我的疑問呢, 原來是跟編譯器有關呢.