拿来主义:C语言动态申请内存案例

来源:互联网 发布:javascript 感染度 编辑:程序博客网 时间:2024/06/05 14:46
两种方法:1.转化为一维数组申请2.先申请全部行首指针,再按行逐行申请1.单次申请:
a=(int *)malloc(sizeof(int),(unsigned)m*n);使用的时候就和一般的二维数组一样。举个例子给你:#include "stdlib.h" #include "stdio.h" #include <malloc.h> int main() { int i,j; int (*p)[10]; //动态生成二维数组格式就是相当与p[10][10],如果想改,自己该里面 的参数,如果想定义n行2列就为: p=(int (*)[2])malloc(n*2*sizeof(int)); p=(int (*)[10])malloc(10*10*sizeof(int)); for(i=0;i<10;i++) for(j=0;j<10;j++) p[i][j]=i*j; for(i=0;i<10;i++) { for(j=0;j<10;j++) printf("%d,",p[i][j]); printf("\n"); } free(p); return 0; }2.多次申请:#include <stdio.h> #include <malloc.h> main() { int i = 0; int j = 0; int line = 0; int row = 0; int **p = NULL; printf("input the line of the array:\n"); scanf("%d", &line); printf("input the row of the array:\n"); scanf("%d", &row); p = (int **)malloc(sizeof(int *) * line); if (NULL == p) {    return; } for (i = 0; i < line; i++) {    *(p + i) = (int *)malloc(sizeof(int) * row);    if (NULL == *(p + i))    {    return;    } } /*input data*/ for (i = 0; i < line; i++) {    for(j = 0; j < row; j++)    {    p[i][j] = i + 1;    } } /*output data*/ for (i = 0; i < line; i++) {    for(j = 0; j < row; j++)    {    printf("%d", p[i][j]);    } } /*free every line point*/ for (i = 0; i < line; i++) {    free(*(p + i));    p[i] = NULL; } free(p); p = NULL; }第一种方法数组创建和释放都比较简单,申请的单元都是连续的,第二种单元不一定是连续的存储单元
0 0