内存分配方式有几种

内存分配方式:

(1)符号起始的区块(.bss段):通常指的是存放程序中未初始化或者初始化为0的变量的和静态数据的区域。bss属于静态内存分配,程序结束后静态资源变量由系统自动释放。

(2)数据段:通常指存放程序中已初始化的全局变量的一块内存区域。也属于静态内存分配。

(3)代码段:有时也叫文本段,通常指的是用来存放程序执行代码(包含类成员函数和全局函数及其他函数代码),这部分区域的大小在程序运行前就已经确定,也有可能包含一些只读的常数变量,例如字符串变量。

(4)堆(heap):用于存放进程运行中被动态分配的内存段,大小不固定。当进程调用malloc或者new等函数时,新分配的内存就被动态添加到堆上(堆被扩张),当使用free或者delete等函数释放内存时,被释放的内存从堆中被删除。需要注意的是,它与数据结构中的堆是两回事,它的分配方式类似于链表。

(5)栈(stack):存放程序临时创建的局部变量,不包括static声明的变量,static意味着在数据段中存放。除此之外,当函数被调用时,其参数也会被压到栈中,并在调用结束后,函数的返回值也会被放到栈中。栈由编译器自动释放。其操作方式类似于数据结构中的栈。栈内存分配运算内置于处理器的指令集中,一般使用寄存器来存取,效率很高,但是分配的内存容量有限。

   引申: 堆数据结构是一种数组对象,它可以被视为一科完全二叉树结构。它的特点是父节点的值大于(小于)两个子节点的值(分别称为大顶堆和小顶堆)

猜你喜欢

转载自blog.csdn.net/qq_41804181/article/details/81224640