动态内存管理(C语言)

1.malloc

2.calloc

 

 calloc  =  malloc + memset

3.realloc

 

这个函数实现原理:如果ptr之后的空间足够,在要扩充的空间之后扩充。

如果不够,重新开辟一个新的空间,并把ptr原内容复制到新空间之前。

ptr指向的空间,必须是一个动态开辟的空间。 

如果ptr是一个空指针,那么realloc等同于malloc

4.free

释放指针,需把该指针变为NULL

当使用free释放时,指针必须指向首地址,上述用法是错误的,因为p不断向后移动,最后不是首地址,应该p[i] = i或者*(p+i) =  i

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
动态内存分配是C语言中一种灵活的内存管理方式,它允许在程序运行时动态地分配和释放内存。而幻方是一个特殊的方阵,其中每一行、每一列和对角线上的元素之和都相等。 在C语言中,可以使用动态内存分配来创建一个幻方。具体步骤如下: 1. 首先,需要定义一个二维数组来表示幻方,例如int类型的二维数组matrix。 2. 接下来,通过动态内存分配函数malloc来为二维数组分配内存空间。根据幻方的阶数n,可以计算出需要的内存空间大小为n * n * sizeof(int)。 3. 分配内存空间后,可以使用for循环来初始化幻方的每个元素。根据幻方的规则,可以将数字从1开始依次填入二维数组中。 4. 最后,可以输出幻方的结果,验证是否满足每行、每列和对角线上元素之和相等的条件。 下面是一个示例代码: ```c #include <stdio.h> #include <stdlib.h> int main() { int n; printf("请输入幻方的阶数:"); scanf("%d", &n); // 动态分配内存空间 int** matrix = (int**)malloc(n * sizeof(int*)); for (int i = 0; i < n; i++) { matrix[i] = (int*)malloc(n * sizeof(int)); } // 初始化幻方 int num = 1; int row = 0, col = n / 2; while (num <= n * n) { matrix[row][col] = num; num++; row--; col++; if (row < 0) { row = n - 1; } if (col == n) { col = 0; } if (matrix[row][col] != 0) { row += 2; col--; if (row >= n) { row -= n; } if (col < 0) { col = n - 1; } } } // 输出幻方 printf("幻方结果:\n"); for (int i = 0; i < n; i++) { for (int j = 0; j < n; j++) { printf("%d\t", matrix[i][j]); } printf("\n"); } // 释放内存空间 for (int i = 0; i < n; i++) { free(matrix[i]); } free(matrix); return 0; } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值