C语言中如何将析构函数编写成一句长尾?
- 内容介绍
- 文章标签
- 相关推荐
本文共计1415个文字,预计阅读时间需要6分钟。
简介+结构函数(Destructors),是对象的成员函数,没有返回值也没有参数,一个类仅有一个析构函数。当对象被销毁时调用,常见于以下几种情况:函数执行结束、对象超出作用域、对象被显式删除等。函数执行结束+程序执行
简介
析构函数(Destructors),是对象的成员函数,没有返回值也没有参数,且一个类只有一个析构函数,当对象被销毁的时候调用,被销毁通常有这么几个情况。
- 函数执行结束
- 程序执行结束
- 程序块包含的局部变量
- delete操作
什么时候要自己写析构函数?
编译器会自动创建默认的析构函数,通常都没有问题,但是当我们在类中动态分配了内存空间时,我们需要手段的回收这块空间,防止内存溢出。就像这样
class String { private: char *s; int size; public: String(char *); // constructor ~String(); // destructor }; String::String(char *c) { size = strlen(c); s = new char[size+1]; strcpy(s,c); } String::~String() { delete []s; }
私有的析构函数
可以将析构函数的访问权限设置为private,设置时没有问题的,但是一个问题就是,通常的手段就没法调用析构函数了。
本文共计1415个文字,预计阅读时间需要6分钟。
简介+结构函数(Destructors),是对象的成员函数,没有返回值也没有参数,一个类仅有一个析构函数。当对象被销毁时调用,常见于以下几种情况:函数执行结束、对象超出作用域、对象被显式删除等。函数执行结束+程序执行
简介
析构函数(Destructors),是对象的成员函数,没有返回值也没有参数,且一个类只有一个析构函数,当对象被销毁的时候调用,被销毁通常有这么几个情况。
- 函数执行结束
- 程序执行结束
- 程序块包含的局部变量
- delete操作
什么时候要自己写析构函数?
编译器会自动创建默认的析构函数,通常都没有问题,但是当我们在类中动态分配了内存空间时,我们需要手段的回收这块空间,防止内存溢出。就像这样
class String { private: char *s; int size; public: String(char *); // constructor ~String(); // destructor }; String::String(char *c) { size = strlen(c); s = new char[size+1]; strcpy(s,c); } String::~String() { delete []s; }
私有的析构函数
可以将析构函数的访问权限设置为private,设置时没有问题的,但是一个问题就是,通常的手段就没法调用析构函数了。

