每日一C之堆与栈的深入理解
每天拾一个C语言贝壳,厚积薄发,积跬步以致千里。
今日贝壳:内存中堆与栈的深入理解。认识一个清晰地内存
假设不清楚内存分配。可阅读【C解析之三】C语言的内存分配。
使用:栈由系统自己主动分配。如局部变量,系统会自己主动在栈中为其开辟空间。
堆由开发者申请分配。
如在C语言中。开发者可通过malloc在堆中开辟空间,C++中则使用new。
方向:栈:方向由高地址向低地址。
堆:方向由低地址向高地址。
系统:栈:系统使用一块连续的内存来实现栈。
连续的整块内存大小必定有限。故栈一般有限制大小,假设须要的栈空间过大。会出现栈溢出。
堆:堆空间从自系统空暇内存链表中分配。
堆空间能够使不连续的内存。使用操作系统的虚拟内存机制。可获得较大的空间。
速度:栈:由系统处理。速度较快。
堆:开发者通过malloc/new申请使用。速度较慢,并easy产生内存碎片与内存泄露等问题。
Have
a nice day !
版权声明:本文博客原创文章,博客,未经同意,不得转载。