3.析构函数

3.析构函数

用类创建一个对象,这个对象使用完毕后,就会调用析构函数,析构函数主要完成清理工作。类的对象时放在栈里面。

析构函数没有返回值和类型声明。

eg:如果构造函数使用new来分配内存,析构函数就需要delete来释放这些内存。

复制代码
Stock::~Stock()
{
​
}

Stock.h

复制代码
#pragma once
#ifndef __Stock__H__
#define __Stock__H__
#include <string>
class Stock
{
private:
    std::string company;
    long num;
    double price;
    double all_price;
    void set_total() { all_price = price * num; }
​
public:
    //void acquire(const std::string &com, double pr, long n);
    Stock(const std::string& com, double pr, long n);
    ~Stock();
    void buy(double n, double pr);
    void sell(double n, double pr);
    void update(double pr);
    void show();
​
​
};
​
#endif

Stock.cpp

复制代码
#include "Stock.h"
#include <iostream>
/*
void Stock::acquire(const std::string& com, double pr, long n)
{
    company = com;
    if (n < 0)
    {
        std::cout << "n < 0 is error!" << std::endl;
        //num = 0;
    }
    else
    {
        num = n;
    }
    price = pr;
    set_total();
}
*/
​
Stock::Stock(const std::string& com, double pr, long n)
{
    company = com;
    if (n < 0)
    {
        std::cout << "n < 0 is error!" << std::endl;
        //num = 0;
    }
    else
    {
        num = n;
    }
    price = pr;
    set_total();
}
Stock::~Stock()
{
    std::cout << "Stock " << company << " is destroyed." << std::endl;
}
void Stock::buy(double n, double pr)
{
    if (n < 0)
    {
        std::cout << "n < 0 is error!" << std::endl;
        //num = 0;
    }
    else
    { 
        num += n;
        price = pr;
        set_total();
    }
}
​
​
void Stock::sell(double n, double pr)
{
    if (n < 0)
    {
        std::cout << "n < 0 is error!" << std::endl;
    }
    else if(n > num)
    {
        std::cout << "n < 0 is error!" << std::endl;
    }
    else
    {
        num = num - n;
        price = pr;
        set_total();
    }
}
​
void Stock::update(double pr)
{
    price = pr;
    set_total();
}
​
void Stock::show()
{
    std::cout << "company: " << company << std::endl;
    std::cout << "num: " << num << std::endl;
    std::cout << "price: " << price << std::endl;
    std::cout << "all_price: " << all_price << std::endl;
}

.

userstock00.cpp

复制代码
#include "Stock.h"
int main()
{
    Stock stock1 = Stock("Apple Inc.", 150.0, 100); //显式地调用构造函数
    Stock stock2("world Cabbage", 250, 1.25);//隐式地调用构造函数
    //stock.acquire("Apple Inc.", 150.0, 100);
    stock1.show();
    //stock.buy(50, 155.0);
    stock2.show();
}

printf:

复制代码
company: Apple Inc.
num: 100
price: 150
all_price: 15000
company: world Cabbage
num: 1
price: 250
all_price: 250
Stock world Cabbage is destroyed.##类的对象时放在栈里面。所以先入后出。
Stock Apple Inc. is destroyed.
​
D:\QT_C++_code\NO.10\1\Project1\x64\Debug\Project1.exe (进程 11848)已退出,代码为 0 (0x0)。
要在调试停止时自动关闭控制台,请启用“工具”->“选项”->“调试”->“调试停止时自动关闭控制台”。
按任意键关闭此窗口. . .

复制代码
stock1 = stock2;
stock1.show();
//stock.buy(50, 155.0);
stock2.show();

类与类之间可以直接赋值。

复制代码
//错误
const Stock land = Stock("Apple Inc.", 150.0, 100);//这个是常量,但是show函数中没有任何保护机制来确保变量不被修改,因而会报错。
land.show();

可以这样改,变成 const成员函数

复制代码
void stock::show() const
{
 ...
}

总结:

构造函数的名称与类名相同,但通过函数重载,可以创建多个同名的构造函数,条件是每个函数的特征标不同。

复制代码
Bozo(const char * fname, const char * lname);
//初始化对象 
Bozo bozetta = Bozo("dfsdf", "fbccbc");
Bozo fufu("dfsdfsdas", "fbccbczxcxz");
Bozo *pc = new Bozo("dfsdf", "fbccbc");

默认构造函数无参数,因此创建对象时没有进行显示初始化,就将调用默认构造函数。如果程序中没有提供任何构造函数,编译器会提供一个默认构造函数;否则必须自己提供默认构造函数。默认构造函数可以没有任何参数,如果有,则必须给所有参数提供默认值。

每个类只能有一个析构函数。构造函数中用了new,必须提供使用了delete的析构函数

相关推荐
qq_479875432 小时前
systemd-resolved.service实验实战3
linux·服务器·c++
gihigo19982 小时前
MATLAB中进行综合孔径微波辐射成像仿真
开发语言·matlab
闻缺陷则喜何志丹2 小时前
【图论 组合数学】P10912 [蓝桥杯 2024 国 B] 数星星|普及+
c++·数学·蓝桥杯·图论
Three K2 小时前
Redisson限流器特点
java·开发语言
Halo_tjn2 小时前
Java 多线程机制
java·开发语言·windows·计算机
Jeff-Nolan2 小时前
C++运算符重载
java·开发语言·c++
YouEmbedded2 小时前
解码智能指针
开发语言·c++·unique_ptr·shared_ptr·auto_ptr·weak_ptr
海上彼尚2 小时前
Go之路 - 7.go的函数
开发语言·后端·golang
神仙别闹2 小时前
基于QT(C++)实现(图形界面)连连看
java·c++·qt