ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

C++面向对象-构造函数与析构函数

2022-09-06 08:00:44  阅读:220  来源: 互联网

标签:ps 0x7fff9908e2d8 SeqStack 函数 与析构 cout C++ 构造函数


以OOP实现一个顺序栈为例, 介绍构造函数与析构函数

#include <iostream>
#include <iterator>
using namespace std;

/*

构造函数和析构函数
    函数的名字和类名一样,没有返回值
*/
class SeqStack {
  public:
    //构造函数有参数,可重载
    SeqStack(int size = 10) {
        cout << this << " SeqStack()" << endl;
        _pstack = new int[size];
        _top = -1;
        _size = size;
    }
    // void init(int size = 10) {
    //     _pstack = new int[size];
    //     _top = -1;
    //     _size = size;
    // }

    //析构函数不带参数,只能有一个,可手动调用释放堆内存
    ~SeqStack() {
        cout << this << " ~SeqStack()" << endl;
        delete[] _pstack;
        _pstack = nullptr;
    }
    // void release() {
    //     delete[] _pstack;
    //     _pstack = nullptr;
    // }
    void push(int val) {
        if (full())
            resize();
        _pstack[++_top] = val;
    }
    void pop() {
        if (empty())
            return;
        --_top;
    }
    int top() { return _pstack[_top]; }
    bool empty() { return _top == -1; }
    bool full() { return _top == _size - 1; }
    void resize() {
        int* ptmp = new int[_size * 2];
        for (int i = 0; i < _size; ++i) {
            ptmp[i] = _pstack[i];
        }
        delete[] _pstack;
        _pstack = ptmp;
        _size += 2;
    }

  private:
    int* _pstack; // 动态开辟数组,存储顺序栈的元素
    int _top;     //指向栈顶元素的位置
    int _size;    //数组扩容总大小
};

int main() {
    // 1. 开辟内存
    // 2. 调用构造函数
    SeqStack s;
    // s.init(5); //对象成员变量的初始化
    for (int i = 0; i < 15; ++i) {
        s.push(rand() % 100);
    }
    while (!s.empty()) {
        cout << s.top() << " ";
        s.pop();
    }
    cout << endl;
    // s.release(); //释放对象成员变量占用的外部堆内存(外部资源)

    //出作用域,对象自动进行析构

    SeqStack s1(50);

    //堆上的一定要手动释放
    SeqStack* ps = new SeqStack(60);
    ps->push(70);
    ps->push(80);
    ps->pop();
    cout << ps->top() << endl;
    delete ps; //先调用ps->~SeqStack() 然后free(ps)

    // 先构造的后析构,后构造的先析构

    // 开始运行...
    // 0x7fff9908e2d8 SeqStack()
    // 63 59 90 27 62 21 49 92 86 35 93 15 77 86 83
    // 0x7fff9908e2b0 SeqStack()
    // 0x527510 SeqStack()
    // 70
    // 0x527510 ~SeqStack()
    // 0x7fff9908e2b0 ~SeqStack()
    // 0x7fff9908e2d8 ~SeqStack()

    // 运行结束。

    return 0;
}

标签:ps,0x7fff9908e2d8,SeqStack,函数,与析构,cout,C++,构造函数
来源: https://www.cnblogs.com/anqwjoe/p/16660346.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有