传统数组
1.灵活性低,都要依赖于预设编译前的大小。
2.内从的泄露和安全隐患。
3.应用受限,可能最后大小不够用了,导致数据溢出。
动态内存分配的效果
1.处理可变数组大小的数据
2.高效数据结构
3.资源优化
栈内存
1.自动管理机制,函数里面的东西用完后会自行释放,函数调用的时候,局部变量会被分配在栈上,当函数返回时,局部变量会全部销毁释放。
堆内存
1.动态管理:maloc calloc realloc,free
我们平时在 C 语言和 C++ 中使用 malloc 和 new 分配的内存就是堆内存,堆内存的一大特点就是大小不固定,可以动态扩容,空间由程序员动态分配,更加灵活。
缺点:
容易产生内存泄露,malloc 出来的没有 free,new 出来的如果没有 delete,都会产生内存泄露,真正项目内存泄露产生的情况肯定比这个复杂得多
容易产生内存碎片,在分配和回收时需要对很多内存碎片进行整理,效率较低,具体可以看下面这个动画
线程不安全,它不像栈内存是线程独立的,堆内存可以被一个进程内所有的线程访问,多线程操作就容易产生问题,很多奇奇怪怪的操作就是这么引起的
2.速度快,栈的访问速度要快于堆,这是一种数据结构。