动态内存管理
由来
很多时候,需要储存的数据量到底有多大往往是一个未知数,要处理好这类情况,就需要使用动态内存。
- 动态内存由一些没有名字、只有地址的内存块构成,那些内存块是在程序运行期间动态分配的。他们来自一个由标准C++库替你管理的大池子(内存池),从内存池申请一些内存需要用到new语句,它将根据你提供的数据类型分配一块大小适当的内存。
- 从内存池申请内存需要使用new语句,它将根据你的需要来给你分配一块合适的内存。如果可用的内存空间不够,那么new语句将抛出std::bad_mallc异常
在使用完内存块之后,应该使用delete语句把它还给内存池,并将与之相关联的指针设置为NULL
因为delete语句只是把申请的内存块释放了,而创建的指针变量依然存在,并且存放着刚刚申请的内存块的地址,所以要将它指向NULL。
拓展:
-
NULL指针:
有一个特殊的地址值叫做NULL指针。当把一个指针变量设置为NULL时,它的含义是那个指针将不再指向任何东西。
注意
- new语句返回的内存块很可能充满“垃圾”数据,所以我们通常先往里边写一些东西覆盖,再访问它们,或者在类直接写一个构造器来初始化。
- 每一个new指针都必须对应着一个相应的delete语句。
为对象分配内存
和其他数据类型的做法是一样的。
- 用new向内存池申请内存。
- 用delete释放内存。
代码实现
#include <iostream>
#include <string>
using namespace std;
class Company
{
public:
Company(string theName);
virtual void printInfo();//需要打印的一些信息
protected:
string name;
};
Company::Company(string theName)//基类构造函数实现
{
name = theName;
}
void Company::printInfo()
{
cout << "这家公司的名字叫:" << name << "。\n";
}
class TechCompany:public Company
{
public:
TechCompany(string theName,string product);
virtual void printInfo();//定义为虚方法,为了使科技公司类中的打印函数能够覆盖基类的打印函数
private:
string product;
};
TechCompany::TechCompany(string theName,string product):Company(theName)//子类构造函数实现
{
this->product = product;
}
void TechCompany::printInfo()
{
cout << name << "公司大量生产了 " << product << "这款产品!\n";
}
int main()
{
Company *company = new Company("APPLE");//定义一个基类对象compnay,为其分配内存,指针指向其地址
company -> printInfo();//调用基类的打印方法
delete company;//删除指针地址
company = NULL;//为指针指向的地址赋空值
company = new TechCompany("APPLE","IPHONE");//指针指向新定义的子类TechCompany
company -> printInfo();//调用子类的打印方法
delete company;
company = NULL;
return 0;
}