一、内存(堆上)分配方式
<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个字节的内存