C++構造函數詳解
文章轉自公眾號:Coder梁(ID:Coder_LT)
上一篇文章我們介紹瞭定義瞭類,在使用之前,往往還需要對類進行初始化。這篇介紹的就是對類進行初始化的方法。
像是結構體,我們可以使用列表初始化的方法進行初始化:
struct Thing { char *pn; int m; }; Thing th = {"hello", 23};
但類不行,因為結構體當中的成員變量都是public
的,而類往往是私有的。這意味著我們不能直接用程序訪問數據成員,需要設計成函數。
在C++當中,這種用來構造類的函數,被稱為類構造函數。構造函數的原型和函數頭有一個比較明顯的特征——它雖然沒有返回值,但沒有被聲明稱void類型,實際上構造函數沒有聲明類型。
比如我們還是之前的類:
class Stock { private: std::string company; long shares; double share_val; double total_val; void set_tot() {total_val = shares * share_val;} public: void accquire(const std::string &co, long n, double pr); void buy(long num, double price); void sell(long num, double price); void update(double price); void show(); }; #endif
現在我們要加入構造函數,首先是在類中加上聲明:
class Stock { ... Stock(const string &co, long n=0, double pr=0.0); }
註意看,我們實現定義的時候,函數是沒有返回類型的:
Stock::Stock(const string &co, long n, double pr) { company = co; if (n < 0) { std::cerr << "Number of shares can't be negative;" << company << " shares set to 0.\n"; shares = 0; }else { shares = n; share_val = pr; set_tot(); } }
註意,構造函數中的參數名不能和類成員名一致,否則會引起錯誤:
Stock::Stock(const string &company, long shares, double share_val) {}
如果一致的話,就會出現這樣的代碼:
shares = shares;
為瞭避免這種混亂,一般會在代碼風格層面加以區分。比如在谷歌代碼規范當中,類中的private成員變量中需要使用後綴_。
最後,我們來看下構造函數的使用。C++當中支持兩種方式,
我們先來看第一種,顯式地調用:
Stock food = Stock("word", 250, 2.5);
另外一種方式是隱式地調用:
Stock garment("furry", 50, 2.5);
這種方式更加緊湊,我們每次使用new
動態分配內存時,也會使用類構造函數。
Stock *pstock = new Stock("ele", 18, 19.0);
構造函數的使用不同於一般的類方法,我們無法使用對象來調用構造函數。
到此這篇關於C++構造函數詳解的文章就介紹到這瞭,更多相關C++構造函數內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- C++類的定義與實現
- python教程命名元組示例分析
- C++實現LeetCode(309.買股票的最佳時間含冷凍期)
- C++私有繼承(一)
- C++實現LeetCode(122.買股票的最佳時間之二)