1、 在程序编译或运行过程中,按事先规定大小分配内存空间的分配方式。int a [10]
2、 必须事先知道所需空间的大小。
3、 分配在栈区或全局变量区,一般以数组的形式。
4、 按计划分配
#include
void *malloc(unsigned int size);
功能:在堆区开辟指定长度的空间,并且空间是连续的
参数:
size:要开辟的空间的大小
返回值:
成功:开辟好的空间的首地址
失败:NULL
注意
1、在调用malloc之后,一定要判断一下,是否申请内存成功。
2、如果多次malloc申请的内存,第1次和第2次申请的内存不一定是连续的
3、使用malloc开辟空间需要保存开辟好的空间的首地址,但是由于不确定空间用于做
什么,所以本身返回值类型为void *,所以在调用函数时根据接收者的类型对其进行强制类
char *str = (char *)malloc(100 * sizeof(char));
#include
void free(void *ptr)
功能:释放堆区的空间
参数:
ptr:开辟后使用完毕的堆区的空间的首地址
返回值:
无
注意:
free§; 注意当free后,因为没有给p赋值,所以p还是指向原先动态申请的内存。但是
内存已经不能再用了,p变成野指针了,所以一般为了放置野指针,会free完毕之后对p赋
为NULL。
一块动态申请的内存只能free一次,不能多次free
#include
void * calloc(size_t nmemb,size_t size);
功能:在堆区申请指定大小的空间
参数:
nmemb:要申请的空间的块数
size:每块的字节数
返回值:
成功:申请空间的首地址
失败:NULL
注意:
malloc和calloc函数都是用来申请内存的。
区别:
例如:
char *p=(char *)calloc(3,100);
在堆中申请了3块,每块大小为100个字节,即300个字节连续的区域。
#include
void* realloc(void *s,unsigned int newsize);
功能:在原本申请好的堆区空间的基础上重新申请内存,新的空间大小为函数的第二个参数
如果原本申请好的空间的后面不足以增加指定的大小,系统会重新找一个足够大的位
置开辟指定的空间,然后将原本空间中的数据拷贝过来,然后释放原本的空间
如果newsize比原先的内存小,则会释放原先内存的后面的存储空间,
只留前面的newsize个字节
参数:
s:原本开辟好的空间的首地址
newsize:重新开辟的空间的大小
返回值:
新的空间的首地址
char *p;
p=(char *)malloc(100)
//想在100个字节后面追加50个字节
p=(char *)realloc(p,150);//p指向的内存的新的大小为150个字节
char *p;
p=(char *)malloc(100)
//想重新申请内存,新的大小为50个字节
p=(char *)realloc(p,50);//p指向的内存的新的大小为50个字节,100个字节的后50个字
节的存储空间就被释放了
注意:malloc calloc relloc 动态申请的内存,只有在free或程序结束的时候才释放。