动态(堆区)内存分配

一、内存(堆上)分配方式

<1>内存分配方式

1.从静态存储区域分配
①内存在程序编译的时候就已经分配好,这块内存在程序的
整个程序运行期间都存在.例如全局变量、static变量.

2.在栈上分配
①在执行函数时,函数内部局部变量的存储单元都可以在栈上
创建,函数执行结束时这些存储单元自动被释放.效率很高,
但是分配的内存容量有限.

3.从堆上分配亦称动态内存分配
①程序在运行的时候用malloc等函数申请【任意多少】的内存,
程序员自己负责在何时用【free】释放内存.动态内存的生存期
由我们决定,使用非常灵活,但问题也最多.
问题:往往申请了,使用完了忘了释放

二、malloc和calloc函数

动态内存分配和释放函数
(申请到的一块连续空间,可看做一个【数组】)

<1>malloc函数使用方法

1.malloc函数 :

 void *malloc(size_t size);

①功能:允许从空闲内存池中分配连续内存但不初始化
②参数:size参数是一个所需字节输的整数
③返回:若【分配成功】则返回一个指向该内存块的指针(通用指针)
在使用时可根据需要做【强制类型】转换,否则返回NULL(空指针)

2.示例

#include <stdio.h>
#include <malloc.h>
/*输出【初始化】【前和后】的内存块内容*/
void out(int*p,int n)
{
    int i;
    for(i=0;i<n;i++)
        printf("%d ",*(p+i));
    printf("\n--------------\n");
}
int main(void)
{
    int n;
    printf("please input one number: ");
    scanf("%d",&n);
    /*向系统申请一个大小为n*4个字节的内存
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值