当前位置: 首页 > news >正文

C语言动态内存开辟

文章目录

    • malloc函数
    • free函数
    • calloc函数
    • realloc函数
    • 二维数组的动态内存开辟

malloc函数

malloc函数包含再#include<stdlib.h>头文件中

void* malloc (size_t size);

这个函数向内存申请⼀块连续可⽤的空间,并返回指向这块空间的指针。

  1. 如果开辟成功,则返回⼀个指向开辟好空间的指针。
    2.如果开辟失败,则返回⼀个 NULL 指针,因此malloc的返回值⼀定要做检查。
    3.返回值的类型是 void* ,所以malloc函数并不知道开辟空间的类型,具体在使⽤的时候使⽤者⾃⼰来决定。
    4.如果参数 size 为0,malloc的⾏为是标准是未定义的,取决于编译器。

free函数

free函数包含再#include<stdlib.h>头文件中
函数free专⻔是⽤来做动态内存的释放和回收的

如果参数 ptr 指向的空间不是动态开辟的,那free函数的⾏为是未定义的。
如果参数 ptr 是NULL指针,则函数什么事都不做。

#include<stdio.h>
#include<stdlib.h>
int main()
{int num=0;scanf("%d",&num);int* arr=(int*)malloc(sizeof(int)*num);if(arr!=NULL){for(int i=0;i<num;i++){printf("%d ",arr[i]);}}free(arr);arr=NULL;return 0;
} 

malloc函数开辟出来的数据是随机值。
动态开辟的空间⼀定要释放,并且正确释放。

calloc函数

void* calloc (size_t num, size_t size);> calloc函数的功能是为 num 个⼤⼩为 size 的元素开辟⼀块空间,并且把空间的每个字节初始化为0
> 与函数 malloc 的区别只在于 calloc 会在返回地址之前把申请的空间的每个字节初始化为0
#include <stdio.h>
#include <stdlib.h>
int main()
{int *p = (int*)calloc(10, sizeof(int));if(NULL != p){int i = 0;for(i=0; i<10; i++){printf("%d ", *(p+i));}}free(p);p = NULL;return 0;
}

动态开辟的空间⼀定要释放,并且正确释放。

realloc函数

有时会我们发现过去申请的空间太⼩了,有时候我们⼜会觉得申请的空间过⼤了,那为了合理的时候内存,我们⼀定会对内存的⼤⼩做灵活的调整。那 realloc 函数就可以做到对动态开辟内存⼤⼩的调整。

void* realloc (void* ptr, size_t size);1.ptr 是要调整的内存地址
2.size 调整之后新⼤⼩
3.返回值为调整之后的内存起始位置。
4.这个函数调整原内存空间⼤⼩的基础上,还会将原来内存中的数据移动到 新 的空间。
5.realloc在调整内存空间的是存在两种情况:
情况1:原有空间之后有⾜够⼤的空间
情况2:原有空间之后没有⾜够⼤的空间
当是情况1的时候,要扩展内存就直接原有内存之后直接追加空间,原来空间的数据不发⽣变化。
当是情况2的时候,原有空间之后没有⾜够多的空间时,扩展的⽅法是:在堆空间上另找⼀个合适⼤⼩
的连续空间来使⽤。这样函数返回的是⼀个新的内存地址。
#include <stdio.h>
#include <stdlib.h>
int main()
{int *p = (int*)calloc(10, sizeof(int));int *pp=realloc(p,sizeof(int)*100);if(pp!=NULL){p=pp;}free(p);p = NULL;return 0;
}

二维数组的动态内存开辟

int main()
{int row=3,col=3;int** arr=(int**)malloc(sizeof(int*)*row);//给行分配空间 for(int i=0;i<col;i++){arr[i]=(int*)malloc(sizeof(int)*col);//给列分配空间 }for(int i=0;i<row;i++){for(int j=0;j<col;j++){arr[i][j]=i+j;//给数组赋值 }}for(int i=0;i<row;i++){for(int j=0;j<col;j++){printf("%d ",arr[i][j]);//打印数组 }printf("\n");}for(int i=0;i<col;i++){free(arr[i]);//释放列 }free(arr);//释放行 return 0;
} 

二维数组动态内存开辟例题转置矩阵

int** transpose(int** matrix, int matrixSize, int* matrixColSize, int* returnSize, int** returnColumnSizes){int m = matrixSize;int n = matrixColSize[0];int i, j;int **res = (int**)malloc(sizeof(int*) * n);*returnColumnSizes = (int*)malloc(sizeof(int) * n);for (i = 0; i < n; i++) {res[i] = (int*)malloc(sizeof(int) * m);(*returnColumnSizes)[i] = m;for (j = 0; j < m; j++) { res[i][j] = matrix[j][i];}}*returnSize = n;return res;
}
int main() {// 定义矩阵大小和列大小int matrixSize = 3; // 假设矩阵有3行int matrixColSize = 3; // 假设矩阵有3列int returnSize = 0; // 用于接收转置后矩阵的行数int* returnColumnSizes = NULL; // 用于接收转置后矩阵每行的列数数组// 创建原始矩阵int** matrix = (int**)malloc(sizeof(int*) * matrixSize);for (int i = 0; i < matrixSize; i++) {matrix[i] = (int*)malloc(sizeof(int) * matrixColSize);}// 填充矩阵数据for (int i = 0; i < matrixSize; i++) {for (int j = 0; j < matrixColSize; j++) {matrix[i][j] = i * matrixColSize + j; // 例如,用行和列的乘积加和来填充}}// 调用 transpose 函数int** transposedMatrix = transpose(matrix, matrixSize, &matrixColSize, &returnSize, &returnColumnSizes);// 打印转置后的矩阵printf("Transposed Matrix:\n");for (int i = 0; i < returnSize; i++) {for (int j = 0; j < returnColumnSizes[i]; j++) {printf("%d ", transposedMatrix[i][j]);}printf("\n");}// 释放内存for (int i = 0; i < matrixSize; i++) {free(matrix[i]);}free(matrix);for (int i = 0; i < returnSize; i++) {free(transposedMatrix[i]);}free(transposedMatrix);free(returnColumnSizes);return 0;
}

http://www.mrgr.cn/news/51033.html

相关文章:

  • 尚硅谷rabbitmq2024 第15-18节 springboot整合与可靠性答疑
  • 在 Spring 中使用 @EhCache 注解作为缓存
  • 如何提高cache miss
  • linux一二三章那些是重点呢
  • 一次Fegin CPU占用过高导致的事故
  • D38【python 接口自动化学习】- python基础之函数
  • OWASP Top 10 漏洞详解:基础知识、面试常问问题与实际应用
  • 自动化生成工作流?英伟达提出ComfyGen:通过LLM来匹配给定的文本提示与合适的工作流程
  • 【论文翻译】HTVGNN:一种用于交通流量预测的混合时间变化图神经网络
  • leetcode hot 100 之【LeetCode 283. 移动零】 java实现
  • 单片机探秘:从理论到应用
  • 2025年国考报名流程详细图解—新手版
  • JavaScript中的面向对象编程(OOP) - 终极指南
  • 【C语言】你不知道的知识小盲区——柔性数组
  • 【进阶OpenCV】 (14)-- 人脸识别 -- LBPH 算法
  • 详解tar.gz, tar.xz, tar, gz后缀文件的区别
  • Windows的Conda环境下使用PlotNeuralNet来绘制神经网络
  • 《最优化方法》
  • 7万字Java后端面试题大全(附答案)——持续更新
  • Python案例 | 测试网络的下载速度上传速度和 ping 延迟