【C基础】动态内存分配

数组元素存储于内存中连续位置,数组被声明时,其所需内存空间在编译时被分配,但数组长度常在运行时才知道,这时需要使用动态分配内存。


malloc: void  *malloc( size_t  size )

// 参数size为需分配的内存字节数,返回一个指向被分配内存块起始位置的指针,若分配失败则返回NULL


free: void  free( void  *pointer )


注:void* 类型指针可转换为其他任何类型的指针


void   *calloc( size_t  num_elements,  size_t  element_size )

// 参数分别为元素个数和一个元素所需内存空间的字节数


void  *realloc( void  *ptr,  size_t  new_size )


注意对内存分配结果做检查


如果指针不是从早先的malloc、calloc、relloc、realloc返回的,不能做参数传递给free   ????应该也可以吧,不过要小心


总结

当数组被声明时,必须在编译时知道他的长度。动态内存分配允许程序为一个长度在运行时才知道的数组分配内存空间。

         malloc 和calloc 函数用于动态分配一块内存,并返回一个指向该快内存的指针。malloc的参数就是需要分配的内存的字节数。和他不同的是,calloc 的参数是你需要分配的元素个数和每个元素的长度。calloc 函数在返回前把内存初始化为0,而malloc 函数返回时内存并未以任何方式进行初始化。调用realloc 函数可以改变一块已经动态分配的内存的大小。增加内存块大小时有可能采取的方法是把原来内存块上的所有数据复制到一个新的、更大的内存块上。当一个动态分配的内存块不再使用时,应该调用free 函数把它归还给可用内存池。内存被释放之后便不能再被访问。

         如果请求的内存分配失败,malloc、calloc和realloc 函数返回的将是一个NULL 指针。错误地访问分配内存之外的区域所引起的后果类似越界访问一个数组,但这个错误还可能破坏可用内存池,导致程序失败。如果一个指针不是从早先的malloc、calloc 或realloc 函数返回的,它是不能作为参数传递个free 函数的。你也不能只释放一块内存的一部分。

         内存泄露是指内存被动态分配以后,当它不再使用时未释放。内存泄露会增加程序的体积,有可能导致程序或系统的崩溃。

         使用sizeof 计算数据类型的长度,提高程序的可移植性。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值