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!

推薦閱讀: