new和delete:
局部变量存储在栈区,由系统来管理内存;
大的内存必须用堆区来存储,但是需要程序员自己申请手动释放。
//申请的内存必须释放
C语言申请大内存用(void*)malloc(size_t);和free(void*);,
其中malloc和free是直接申请和释放内存。
//size_t:typedef unsigned int size_t
C++中申请大内存用new和delete,
其中new是先申请内存,后调用构造函数;delete是先调用析构函数,后释放内存。
new和delete控制的内存在自由存储区,一般自由存储区在堆区。
new myString();//在堆区创建一个对象,会调用其构造函数
语法格式:
myString* msl = new myString();
delete msl;//先调用析构函数,再释放对象的内存
1 string* str1 = new string;
2 string* str2 = new string();//两种方式起到同等效果
string* str3 = new string("nihao");//传参,可传多个
上面释放空间代码:
1 delete str1;
2 delete str2;//delete只能delete掉new申请的空间
在C语言中,创建数组以及释放空间代码:
1 int arr[20];
2 int* arrc = (int*)malloc(sizeof(int)*20);
3 free(arrc);//(重点) arrc = NULL
在C++中,创建数组以及释放空间代码:
1 int* arr = new int[20];
2 myString* myArrs = new myString;//会依次调用每个对象的无参(默认)构造函数
3 delete[] arr;//释放数组时,必须用对应的delete[]来释放
4 delete[] myArrs;//会依次调用每个对象的析构函数
由上面的c++创建数组以及释放空间可以写出创建一个动态数组以及释放空间代码:
1 vector<int>* varr = new vector<int>();
2 delete varr;
malloc申请内存不成功会返回0(NULL);
new申请内存不成功会抛出异常。
delete不改变这个指针的值,释放后该指针变成野指针。
#include<iostream>
#include<vector>
#include<string>
using namespace std;
//为什么要在申请内存之后释放内存?
//防止内存泄漏
//什么是内存泄漏?如果内存泄漏会发什么问题?
//内存泄漏就是在没有释放内存的时候,使得不同指针指向同一空间,最终耗尽系统的内存。
int main() {
int* arr = (int*)malloc(10 * sizeof(int));//c风格的申请内存
free(arr);//c风格的释放内存
int* carr = new int();//c++使用new和delete来申请内存和释放内存
delete carr;
return 0;
}
/*
内存泄漏会减少可用内存的数量,从而降低计算机的性能。最终,在最坏的情况下,它可能会分配太多的可用内存,并且系统或设备会全部或部分停止正常工作,应用程序会瘫痪,或者系统由于颠簸而大大变慢。
*/