堆区与栈区的区别:
1、管理方式:堆区是由程序员管理;栈由系统自动管理。
2、碎片问题:栈是不存在内存碎片问题的,因为栈的储存机制是‘后进先出’,当运行到某参数时,在其前面的参数都已经出站了。而频繁的申请释放操作会导致大量的内存碎片,降低程序的效率。
可见堆容易造成内存碎片,由于没有专门的系统,极大地降低了程序的效率。
3、生长方式:堆是由低地址向高地址扩张,地址是连续的;栈是由高地址向低地址扩张,地址是不连续的。
什么是内存碎片: 内存碎片一般是由于空闲的连续空间比要申请的空间小,导致这些小内存块不能被利用。产生内存碎片的方法很简单,举个例:
假设有一块一共有100个单位的连续空闲内存空间,范围是0~99。如果你从中申请一块内存,如10个单位,那么申请出来的内存块就为0~9区间。这时候你继续申请一块内存,比如说5个单位大,第二块得到的内存块就应该为10~14区间。
如果你把第一块内存块释放,然后再申请一块大于10个单位的内存块,比如说20个单位。因为刚被释放的内存块不能满足新的请求,所以只能从15开始分配出20个单位的内存块。
现在整个内存空间的状态是0~9空闲,10~14被占用,15~24被占用,25~99空闲。其中0~9就是一个内存碎片了。如果10~14一直被占用,而以后申请的空间都大于10个单位,那么0~9就永远用不上了,造成内存浪费。
如果你每次申请内存的大小,都比前一次释放的内村大小要小,那么就申请就总能成功。
4、分配方式:栈可以进行动态分配,也可以进行静态分配;堆只能动态分配,且只能手动释放。