温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

C++对象的销毁之析构函数实例分析

发布时间:2022-04-19 09:09:32 来源:亿速云 阅读:170 作者:iii 栏目:开发技术

本文小编为大家详细介绍“C++对象的销毁之析构函数实例分析”,内容详细,步骤清晰,细节处理妥当,希望这篇“C++对象的销毁之析构函数实例分析”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

一、对象的销毁

  • 生活中的对象都是被初始化后才上市的

  • 生活中的对象被销毁前会做一些清理工作

  • —股而言,需要销毁的对象都应该做清理

解决方案

  • 为每个类都提供一个 public 的 free 函数

  • 对象不再需要时立即调用 free 函数进行清理

如下:

C++对象的销毁之析构函数实例分析

存在的问题

  • free 只是一个普通的函数,必须显示的调用

  • 对象销毁前没有做清理,很可能造成资源泄漏

C++ 编译器是否能够自动调用某个特殊的函数进行对象的清理?

二、析构函数

C++ 的类中可以定义一个特殊的清理函数

  • 这个特殊的清理函数叫做析构函数

  • 析构函数的功能与构造函数相反

定义:~ClassName()

  • 析构函数没有参数也没有返回值类型声明

  • 析构函数在对象销毁时自动被调用

下面开始简单使用析构函数:

#include <stdio.h>
 
class Test
{
public:
    Test()
    {
        printf("Test()\n");
    }
    ~Test()
    {
        printf("~Test()\n");
    }
};
 
int main()
{
    Test t;
    
    return 0;
}

输出结果如下:

C++对象的销毁之析构函数实例分析

t 虽然是对象,但是本质上也是局部变量,在 return 0 之前会销毁,t 被销毁时析构函数会被自动调用。

下面再来看一个例子:

#include <stdio.h>
 
class Test
{
    int mi;
public:
    Test(int i)
    {
        mi = i;
        printf("Test(): %d\n", mi);
    }
    ~Test()
    {
        printf("~Test(): %d\n", mi);
    }
};
 
int main()
{
    Test t(1);
    
    Test* pt = new Test(2);
    
    delete pt;
    
    return 0;
}

输出结果如下:

C++对象的销毁之析构函数实例分析

析构函数的定义准则

当类中自定义了构造函数,并且构造函数中使用了系统资源(如∶内存申请,文件打开,等) ,则需要自定义析构函数。

下面再来看一个实验:

IntArray.h:

#ifndef _INTARRAY_H_
#define _INTARRAY_H_
 
class IntArray
{
private:
    int m_length;
    int* m_pointer;
public:
    IntArray(int len);
    IntArray(const IntArray& obj);
    int length();
    bool get(int index, int& value);
    bool set(int index ,int value);
    ~IntArray();
};
 
#endif

IntArray.cpp:

#include "IntArray.h"
#include "stdio.h"
 
 
 
IntArray::IntArray(int len)
 
{
 
    m_pointer = new int[len];
 
    
 
    for(int i=0; i<len; i++)
 
    {
 
        m_pointer[i] = 0;
 
    }
 
    
 
    m_length = len;
 
}
 
 
 
IntArray::IntArray(const IntArray& obj)
 
{
 
    m_length = obj.m_length;
 
    
 
    m_pointer = new int[obj.m_length];
 
    
 
    for(int i=0; i<obj.m_length; i++)
 
    {
 
        m_pointer[i] = obj.m_pointer[i];
 
    }
 
}
 
 
 
int IntArray::length()
 
{
 
    return m_length;
 
}
 
 
 
bool IntArray::get(int index, int& value)
 
{
 
    bool ret = (0 <= index) && (index < length());
 
    
 
    if( ret )
 
    {
 
        value = m_pointer[index];
 
    }
 
    
 
    return ret;
 
}
 
 
 
bool IntArray::set(int index, int value)
 
{
 
    bool ret = (0 <= index) && (index < length());
 
    
 
    if( ret )
 
    {
 
        m_pointer[index] = value;
 
    }
 
    
 
    return ret;
 
}
 
 
 
IntArray::~IntArray()
 
{
    printf("do it\n");
 
    delete[]m_pointer;
 
}

main.cpp:

#include <stdio.h>
#include "IntArray.h"
 
int main()
{
    IntArray a(5);    
    
    for(int i=0; i<a.length(); i++)
    {
        a.set(i, i + 1);
    }
    
    for(int i=0; i<a.length(); i++)
    {
        int value = 0;
        
        if( a.get(i, value) )
        {
            printf("a[%d] = %d\n", i, value);
        }
    }
    
    IntArray b = a;
    
    for(int i=0; i<b.length(); i++)
    {
        int value = 0;
        
        if( b.get(i, value) )
        {
            printf("b[%d] = %d\n", i, value);
        }
    }
    
    return 0;
}

输出结果如下:

C++对象的销毁之析构函数实例分析

可以看到 do it 输出两次,也就是说析构函数被自动调用两次。

读到这里,这篇“C++对象的销毁之析构函数实例分析”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

c++
AI