1.为什么出现动态内存分配?
对于以前的内存开辟方式:比如说在栈上开辟的空间。
(1)int a=1; 在栈上开辟4个字节的空间
(2)char arr[10]={0}; 在栈开辟10个字节的连续空间
这样的方法有两个特点:
(1)空间开辟的大小是固定的。
(2)数组在定义时,必须指定数组长度。
但是这样做的弊端在于:无法开辟大量空间,不能得到变长数组
所以出现了动态内存分配函数。
2.malloc
(1)void *malloc(size_t size);
它是向内存申请一块连续可用的空间,并返回指向这块空间的指针。
如果开辟成功,则会返回指向开辟好内存空间的指针;
如果开辟失败,则会返回NULL指针,所以开辟之后要做检查。
返回值是void * 类型,所以malloc 函数与类型无关,并不知道开辟空间的类型。
如果参数size为0,则malloc 的行为是标准未定义的,取决于编译器。
在堆上申请空间,由程序员申请,由程序员释放,如果不释放,可能造成内存泄漏。
(2)void free(void ptr);
free函数用来释放动态开辟的内存。