C++中的构造函数与析造函数详解

 更新时间:2017年06月26日 14:13:05   作者:ab198604  
这篇文章主要介绍了C++中的构造函数与析造函数详解的相关资料,需要的朋友可以参考下

C++中的构造函数与析造函数详解

 构造函数的概念

        (1)构造函数是特殊的成员函数
        (2)当创建类类型的新对象时,系统自动会调用构造函数
        (3) 构造函数是为了保证对象的每个数据成员都被正确的初始化。        

        创建构造函数的注意事项:

        (1) 函数名与类名相同;
        (2) 没有返回类型,返回类型也不能是void型
        (3) 构造函数通常情况下声明为public,否则不能像其它成员函数那样被显示的调用
        (4) 构造函数也可以声明为private,但是是用作特殊用途-----如单例类singleton时就是将构造函数声明为private.
        (5) 构造函数可以有任何类型与任意个数的参数,一个类可以定义多个构造函数(重载)

        关于默认构造函数:

        默认构造函数是构造函数的其中一种。除此之外,还有拷贝构造函数与转换构造函数,这个后期再说明。默认构造函数是不带任何参数的构造函数,如果程序中未声明定义任何一个构造函数,则系统将自动产生一个默认的构造函数,此时不会对对象数据成员进行初始化,那么对象数据成员的值将是随机的。而如果我们提供了一个构造函数(只要是构造函数,无论是带参数的,还是不带参数的,是拷贝还是转换构造函数),哪怕只提供了仅仅一个构造函数,系统就不会再为我们提供默认构造函数了。

        下面是关于构造函数的类定义:

class Test 
{ 
public: 
  Test(){} //系统不再提供默认构造函数 
  Test(int val) //构造函数可以重载 
  { 
    val_ = val ; 
  } 
  ~Test(){} 
 
private: 
  int val_; 
}; 

        下面代码是Test类的使用:

int main() 
{ 
  Test t1; //系统调用不带参数的默认构造函数 
  Test t2(5); //系统调用带一个参数的构造函数 
   
  Test *t3 = new Test(20); //分配内存+调用带一个参数的构造函数,这种操作称为new operator. 
 
  delete t3; // 调用析构函数+ 释放内存 
} 

        请注意:全局对象的构造函数是先于main函数执行的       

析构函数概念

        (1) 函数名与类名类似,前面多了一个"~"符号(取反符)
        (2) 没有返回类型
        (3) 不能有参数
        (4) 不能被重载(这个好理解,因为没有参数,自然不能重载)
        (5) 如果没有定义析构函数,则编译器会自动生成一个默认的析构函数,函数体是空的。

 析构函数与对象数组

        把握一个原则,构造几个对象,就要调用几次析构函数。

        拿上面的Test类来进行举例说明:

int main() 
{ 
  Test t[2] = {10,20}; //对象数组初始化,创建2个元素,即2个Test对象,分别传递初始值为10,20,就是说调用的是带一个参数的构造函数。由于创建了2个对象,构造函数也调用了两次 
  Test *t2 = new Test(2); //仅创建一个对象,初始值为2,调用带一个参数的构造函数。 
 
  delete t2; //调用一次析构函数。 
 
  Test *t3 = new Test[2]; //在堆上创建2个对象,无初始值,调用的是不带参数的默认构造函数,由于是2个对象,故调用了2次。 
 
  delete [] t3; //调用两次析构函数,还有释放内存操作。 
} 

        注意:析构函数可以被显式调用,但是当对象的生命周期结束后,系统还会再调用一次析构函数,这样就造成了调用2次析构函数,如果在析构函数中含有delete操作,就会出现问题。所以析构函数的显式调用比较少。STL源码中有用到析构函数的显式调用,这属于一些特殊用法。

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

相关文章

  • C++基于字符串实现大数相乘问题的代码详解

    C++基于字符串实现大数相乘问题的代码详解

    在实际编程中,我们经常会遇到需要处理大整数的情况,由于编程语言中内置整数类型有其表示范围的限制,当需要处理的整数超出这些范围时,就不能直接使用内置类型进行计算,所以本文给大家介绍了相关的解决方法,需要的朋友可以参考下
    2025-03-03
  • c++ 创建型设计模式工厂方法Factory Method示例详解

    c++ 创建型设计模式工厂方法Factory Method示例详解

    这篇文章主要为大家介绍了c++ 创建型设计模式工厂方法Factory Method示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-09-09
  • c++双向链表操作示例(创建双向链、双向链表中查找数据、插入数据等)

    c++双向链表操作示例(创建双向链、双向链表中查找数据、插入数据等)

    这篇文章主要介绍了c++双向链表操作示例,包括创建双向链、删除双向链表、双向链表中查找数据、插入数据等,需要的朋友可以参考下
    2014-05-05
  • C语言实现大数据文件的内存映射机制

    C语言实现大数据文件的内存映射机制

    这篇文章主要介绍了C语言实现大数据文件的内存映射机制的相关资料,需要的朋友可以参考下
    2017-01-01
  • vs2022重新编译opencv-python cuda加速时报错的问题解决

    vs2022重新编译opencv-python cuda加速时报错的问题解决

    本文主要介绍了vs2022重新编译opencv-python cuda加速时报错,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-04-04
  • Matlab实现带竖线散点的核密度图的绘制

    Matlab实现带竖线散点的核密度图的绘制

    核密度估计是用于估计随机变量概率密度函数的一种非参数方法。核密度图不失为一种用来观察连续型变量分布的有效方法。本文将用Matlab实现带竖线散点的核密度图的绘制,感兴趣的可以了解一下
    2022-08-08
  • notepad介绍及插件cmake编译过程(替代notepad++)

    notepad介绍及插件cmake编译过程(替代notepad++)

    这篇文章主要介绍了notepad介绍及插件cmake编译过程(替代notepad++),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-03-03
  • C++中事件机制的简洁实现及需要放弃的特性

    C++中事件机制的简洁实现及需要放弃的特性

    事件模型是被广泛使用的好东西,但是C++标准库里没有现成的,现在VC11可以用在XP下了,那么就痛快的拿起C++11提供的先进设施组合出一个轻便的实现吧感兴趣的朋友可以了解下,或许对你有所帮助
    2013-02-02
  • C语言 模拟实现strlen函数详解

    C语言 模拟实现strlen函数详解

    在 C 语言 中我们要获取 字符串 的长度,可以使用strlen 函数,strlen 函数计算字符串的长度时,直到空结束字符,但不包括空结束字符,因为 strlen 函数时不包含最后的结束字符的,因此一般使用 strlen函数计算的字符串的长度会比使用 sizeof 计算的字符串的字节数要小
    2022-04-04
  • C++基于CMD命令行实现扫雷小游戏

    C++基于CMD命令行实现扫雷小游戏

    这篇文章主要为大家详细介绍了C++基于CMD命令行实现扫雷小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-05-05

最新评论