可能的重复:
堆和堆栈内存是如何管理、实现和分配的?
,
我的问题是关于堆,不是数据结构,而是用于动态内存分配的内存区域。
假设我们正在用 C(或者可能是 C++)编写一个程序,并且在其代码深处的某个地方调用了 malloc() (或者在 C++ 的情况下调用了operator new)。现在分配的内存位置在哪里?编译器(链接器?)是否添加用作堆的数据段?该段的大小是如何确定的?如果我们尝试分配一块大于整个“堆段”的内存,会发生什么?堆会扩展吗?如果是,怎么办?
Possible Duplicate:
How is heap and stack memories managed, implemented, allocated?
Hi,
my question is about heap, not the data structure, but the area of memory that is used for dynamic memory allocation.
Suppose we're writing a program in C (or maybe C++) and somewhere in the depths of its code a call to malloc() is made (or operator new is invoked, in case of C++). Now what is the location of the allocated memory? Does the compiler (linker?) add a data segment that is used as a heap? How is the size of that segment determined? What will happen if we try to allocate a chunk of memory that is bigger than the entire "heap segment"? Will the heap be expanded? If yes, how?
发布评论
评论(3)
操作系统分配页面,然后将其返回给 malloc/free,然后将这些页面从内存中分成所需大小的块。操作系统可以分配用户地址空间中尚未请求的任何页面。没有堆段。分配的内存位于操作系统确定的任何位置。
The OS allocates pages, which it returns to malloc/free, which then break those pages up into blocks of the requested size, from memory. The OS can allocate any pages in the user's address space that aren't already requested. There is no heap segment. The allocated memory is in whatever location the OS determines.
有 dlmalloc 内部工作原理的描述(glibc、uClibc 和许多其他地方使用的 malloc() 实现)此处。
类 Unix 操作系统有两个用于请求/释放内存的主要接口:
Windows API实际上类似于malloc()/free(),具有HeapAlloc()/HeapFree()等函数。
There is a description of the inner workings of dlmalloc (the malloc() implementation used on glibc, uClibc and many other places) here.
Unix-like OSes have two main interfaces for requesting/releasing memory:
The Windows API is actually malloc()/free() like, with function like HeapAlloc()/HeapFree().
旧的unix实现使用机制
sbrk()
——移动最后一个数据段边界的系统请求。当分配内存时,tuntime库调用系统将数据边界向上移动,并使用新来的内存。新的操作系统使用虚拟内存,因此 malloc 在必要时向系统请求新的空闲 VM 页面。
独立应用程序(在裸硬件、微控制器等上运行)拥有所有已分配的内存。库知道所有内存,因为链接器脚本定义了动态区域的符号。例如诸如
freemembot
和freememtop
之类的东西,用于最低和最高的可用内存区域位置。Old unix implementations used mechanism
sbrk()
--system request for moving last data section boundary. When memory is allocated, tuntime library calls system to move data boundary up, and use newly coming memory.New operational systems use virtual memory, so malloc requests new free VM pages from the system when necessary.
Standalone applications (which run on bare hardware, microcontrollers etc.) have all allocated memory. Library know about all memory because linker script defines symbols for dynamic area. E. g. something like
freemembot
andfreememtop
, for lowest and highest free memory area location.