类的构造函数和析构函数

我们之前使用的初始化方法大多如下面的形式:

//1.
int year = 1998;

//2.
struct MyString
{
      char *ppp;
      int  num;
};
MyString bbb = {"DoubleKill",2};

接我们之前创建的Stock类。如果我们使用下面的方式初始化Stock类的对象,编译器就会报错,

Stock hot = {"M78,Inc.",400,11.11};

之所以不能像上面那样初始化,是因为数据部分的访问状态是私有的,程序不能直接访问数据成员,如下:

Stock gift;
gift.buy(11,11.11);

Stock类之前的实现来说,gift对象的company成员是没有值的。类设计假设用户在调用任何其它成员函数之前调用acquire(),但是却无法加强这种假设。这是个问题,避开这种问题的方法之一就是在创建对象时,自动对他进行初始化。因此,我们需要使用类构造函数

一、类构造函数:

类构造函数专门用于构造新对象、将值赋值给它们的的数据成员。类构造函数的原型和函数头有一个共同特点:没有返回值,但也没有被声明为void类型

1.声明和定义类构造函数

我们给Stock类创建构造函数,程序在声明对象时讲自动调用构造函数,构造函数一般有下面三种原型样式;

Stock();
Stock(const string & co = "NSError",long n = 0, double pr = 0.0);

Stock(const string & co ,long n, double pr);

第一、三种原型的定义实现为:

Stock::Stock()
{
    cout << "Default constructor called " << endl;
    company = "No name";
    share_value = 0;
    share_value = 0.0;
    total_value = 0.0;
}

Stock::Stock(const string & co ,long n, double pr)
{
    company = co;
    if (n < 0)
    {
        cerr << "number of share can't be negative."
             << company
             << "shares set to 0."
             << endl;
        share = 0;
    }
    else
    {
        share = n;
    }
    share_value = pr;
    set_tot();
}

注意:

为了防止构造函数的参数名和成员变量的名称相同,在声明成员变量时可以在前面加上m_或者在后面加上_。如下样式:

class Test {
private:
    double m_share;
    double m_share_value;

    double total_value_;
    string company_;

public:

};

2.使用构造函数

在C++中提供了两种使用构造函数初始化对象的方式
第一种:显式调用构造函数

    Stock fuck = Stock("L77.Xingyun.Inc", 1314, 22.22);

第二种:隐式调用构造函数

    Stock penta_kill("L77.Xingyun.Inc", 1314, 22.22);
3.默认构造函数

定义默认构造函数的方式有两种:
第一种:给已有构造函数的所有参数提供默认值

Stock(const string & co = "NSError",long n = 0, double pr = 0.0);

第二种:通过函数重载来定义一个没有参数的构造函数

Stock();

它的实现请参考上面的代码。

注意
在设计一个类时,通常应提供对所有类成员做隐式初始化的默认构造函数
4.析构函数

用构造函数创建对象后,程序负责跟踪该对象,直到对象过期为止。在对象过期时,程序将自动调用一个特殊的成员函数来完成清理工作。
如果构造函数使用new来分配内存,则析构函数将使用delete来释放这些内存。在Stock中构造函数没有使用new来分配 内存,因此对应的析构函数实际上也就没有需要完成的任务。
析构函数,比如Stock的析构函数原型为:~Stock();,它的实现一般为:

Stock::~Stock()
{
    //Do something in here.
}
5.const成员函数

如下:

const Stock duke = Stock("The company string.");
duke.show();//complier refuse execute

编译器会拒绝执行第二步,因为duke是通过const修饰的Stock对象,不能被修改,但show()里面的代码无法保证duke对象不被修改。
解决办法:

1.声明show()函数时在后面加const,即void show() const;.
2.实现show()函数,即,void Stock::show() const

你可能感兴趣的:(类的构造函数和析构函数)