预备知识
代码中定义的普通变量,会在栈区分配一个对应大小的内存空间,栈区的存储空间小;
代码中定义的动态变量则是在堆区,堆区的存储空间相比于栈区大很多;
为什么需要动态内存
- 相比与定义一个普通变量,定义一个动态变量能使用的内存空间更大,当你的某个变量有很多的存储需求时,动态分配内存能满足你的需求
- 当你需要定义的某个变量的大小是可变的且范围较大,这个时候你定义一个普通变量,会分配一个固定大小的内存,当需要存入的数据较小的时候,大量的内存空间被浪费了,数据较大时容易溢出,你为了防止内存溢出还不得不给这个变量足够大的内存,若只有少数几个这样的变量,也只是内存浪费,但是对于大型项目,可能会存在很多这样的变量,这个时候栈区就可能被撑爆掉(栈区很小嘛);这个时候,动态内存分配就闪亮登场了,反正很有钱(堆区空间大嘛),为了保证出去玩钱够用(防止内存溢出),可以往银行卡里打入足够的钱(预分配足够的内存空间),需要花多少钱就用多少钱(变量有多大就用多大的内存,不怕内存浪费,因为:动态!可大可小!)
- 动态内存的分配是用指针实现的,定义动态内存实际上是定义了一个指针,该指针指向了某一块内存空间,传递指针比传递整个变量更加高效
- 当在一个函数/块中动态分配一个内存,当函数/块结束后它并不会被释放,仍然需要手动释放内存,而在栈区定义的普通变量在函数/块结束后会自动释放内存,这里也说明了动态定义的变量的生存期是要比普通变量长的,且生存期的长短可以由你来控制