动态分配二位数组

C++动态内存分配详解
new操作符:
在堆上申请一段内存,返回这段内存的首地址

你想给个二维数组动态分配内存,由于它在内存中仍然是顺序排列的,所以可以以一维数组的形式分配内存,维数 = 行数 * 列数

至于直接分配不能执行的原因在于,你new一个二维数组,那么它的返回类型是什么呢,是一个指向一维数组的指针,而指向数组的指针类型,是包涵维数信息的,这个维数需const量表示

给你一个例子说明

int main()
{
    int row1, col1;
    cin >> row1 >> col1;
    int *p1 = new int[row1 * col1];
    //use the p1 ...
    delete [] p1;

    cout << "okokok" << endl;

    int row2;
    cin >> row2;
    const int col2 = 3;
    int (*p2)[3] = new int[row2][3];    //指向数组的指针类型,包含维数信息,维数需个常数
    //use the p2
    delete []p2;

    return 0;
}

 
对于多维数组的动态分配,高维维数需编译时常量,才能好的执行
### 使用 `malloc` 函数在 C 语言中分配二维数组 #### 方法一:按行分配 此方法涉及为每一行单独分配内存。这种方式创建的是指针数组,其中每个元素指向另一块内存区域。 ```c #include <stdio.h> #include <stdlib.h> int main() { int rows = 3; int cols = 4; // 创建一个指向整数指针的指针,并为其分配足够的空间来保存rows个指针 int **array = (int **)malloc(rows * sizeof(int *)); if (!array) { fprintf(stderr, "Failed to allocate memory.\n"); exit(EXIT_FAILURE); } // 逐行为每行分配cols大小的空间 for (int i = 0; i < rows; ++i) { array[i] = (int *)malloc(cols * sizeof(int)); if (!array[i]) { while (--i >= 0) free(array[i]); free(array); fprintf(stderr, "Failed to allocate memory.\n"); exit(EXIT_FAILURE); } } // 填充数据并打印出来验证正确性 for (int i = 0; i < rows; ++i) { for (int j = 0; j < cols; ++j) { array[i][j] = i * cols + j; printf("%d ", array[i][j]); } puts(""); } // 清理资源 for (int i = 0; i < rows; ++i) free(array[i]); free(array); return EXIT_SUCCESS; } ``` 这种方法的优点是可以方便地访问和操作各个子数组[^1]。 #### 方法二:一次性分配大块连续内存 该方式将整个二维结构视为单一的一维数组处理,即只调用一次 `malloc()` 来获取所需全部字节长度的记忆体区块。 ```c #include <stdio.h> #include <stdlib.h> int main() { const size_t rows = 3; const size_t cols = 4; // 计算总需字节数量,并尝试获得相应数量的连续存储单元 int (*array)[cols] = (int (*)[cols])malloc(sizeof(*array) * rows); if (!array) { perror("Error allocating memory"); exit(EXIT_FAILURE); } // 测试填充与显示矩阵中的数值 for (size_t row = 0; row < rows; ++row) { for (size_t col = 0; col < cols; ++col) { array[row][col] = static_cast<int>(row * cols + col); printf("%d ", array[row][col]); } putchar('\n'); } // 解放之前所占有的动态储存区 free(array); return EXIT_SUCCESS; } ``` 这里采用了一种更简洁的方式定义了一个固定宽度(列数)的多维数组指针变量[^4]。 #### 方法三:混合模式 结合上述两种策略的特点,在某些情况下可能会更加灵活适用: ```c #include <stdio.h> #include <stdlib.h> typedef struct Matrix { double *data; unsigned width; } matrix_t; matrix_t* create_matrix(unsigned height, unsigned width) { matrix_t *m = (matrix_t*)malloc(sizeof(matrix_t)); m->width = width; m->data = (double*)malloc(height * width * sizeof(double)); return m; } void destroy_matrix(matrix_t *m) { free(m->data); free(m); } // 示例使用 int main(void){ matrix_t *mat = create_matrix(5,7); mat->data[0]=9.8f; destroy_matrix(mat); return 0; } ``` 这种做法不仅能够有效地管理大型稀疏矩阵的数据布局,而且还能简化接口设计[^3]。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值