文章目录
- 创建
- 参考博客
😊点此到文末惊喜↩︎
创建
- 指针数组的方式
- 使用malloc和free可以兼容c
- 相比于使用STL可以更加灵活
- 但是debug可能数组显示不全
// 初始化
int **arr;
int row = 5;//用于表示行数
int col = 5;//用于表示列数
arr = new int*[row];//开辟一块内存来存放每一行的地址
for (int i = 0; i < row; i++)//分别为每一行开辟内存
arr[i] = new int[col];
// 释放
for (int i = 0; i < row; i++)
delete [] arr[i];
- vector的方式
- vector的内存空间只增不减,初始化含有100个元素的vector,然后erase掉99个,留下一个有效元素,内存占用仍为100。
内存空间是在vector析构时才被系统回收
,同样使用clear之后,vector所占的内存空间依然不变 - vector的内存空间只增加不减少,erase和clear只是减少了size,并不会减少capacity,所以内存空间没有减少,使用swap可以释放内存空间
- vector的内存空间只增不减,初始化含有100个元素的vector,然后erase掉99个,留下一个有效元素,内存占用仍为100。
int rows = 3;
int cols = 8;
vector<vector<int>> vec;
// 空间创建
vec.resize(cols);
for(int i = 0; i < vec.size(); i++){
vec[i].resize(rows);
}
// 初始化
for(int i = 0; i < cols; i++)
for(int j = 0; j < rows; j++){
vec[i][j] = 1;
}
🚩点此跳转到首行↩︎
参考博客
- 动态创建二维数组的两种方法
- C/C++动态二维数组的内存分配和释放
- [C++ vector内存分配与释放机制
- 待定引用