C语言-动态内存分配

本文探讨了C语言中动态内存分配的必要性,通过对比传统数组与动态数组,阐述了动态内存分配如何解决静态数组的局限性。通过示例介绍了malloc函数的使用,以及动态数组的构造和内存释放。此外,还分析了静态内存和动态内存的区别,并讨论了跨函数使用内存的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

传统数组的缺点

数组的长度必须事先进行指定,且只能是常整数,不能够是变量
例如

 int a[5]; //这是正确的
 int len;
 int a[len]; //这是错误的。传统的数组不能够是变量

传统形式定义的数组。该数组在内存中的空间,程序员无法手动进行释放。在一个函数运行期间,系统为该函数中数组分配的空间会一直存在,直到该函数运行结束时,该数组的空间才会被系 统释放。
例如

 #include<stdio.h>
 void f(void)
 {
  int a[4]={1,2,3,4};
  return;
 }
 int main(void)
 {
  f();
  return 0;
 }
 ​
 //数组 a 在内存中的空间会一直存在 ,直到函数 f 执行完成,系统才会释放内存中数组的空间。

数组的长度一旦定义就不能够进行更改
数组的长度不能在函数的运行过程中,动态的扩充或者缩小

A函数定义的数组,在A函数运行期间可以被其他函数进行使用。在A函数终止后,A函数中的数组就不能够被其他函数进行使用
例如:

 #include<stdio.h>
 void g(int* parr,int len)
 {
  parr[3]=88;
 }
 void f(void)
 {
  int a[4]={1,2,3,4};
  g(a,4);
  printf("a[3]=%d\n",a[3]);
 }
 int main(void)
 {
  f();
  return 0;
 }
 ​
 /*
 上面程序就说明了,一旦 f 函数终止了,g 函数中调用的 f 函数中数组 a 就会失败,
 */


总结一下就是:
传统函数定义的数组不能够跨函数使用。


为什么需要动态分配内存

动态数组很好的解决了传统数据的缺陷。

传统数组也叫静态数组。


动态内存分配举例——动态数组的构造

1. 首先我们来讲讲malloc函数

malloc函数是 memory(内存) allocate(分配)的缩写。也就是内存分配函数。

举个例子

 #include<stdio.h>
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值