我知道你必须这样做:
int * p;
p = new int[10];
//use array
delete [] p;
现在我的问题是:由于没有明确说明,如何释放正确的内存量?操作系统是否跟踪分配的内存及其起始地址?
我知道你必须这样做:
int * p;
p = new int[10];
//use array
delete [] p;
现在我的问题是:由于没有明确说明,如何释放正确的内存量?操作系统是否跟踪分配的内存及其起始地址?
是的,操作系统(或更可能是库)保持跟踪。
当您分配内存时,操作系统会为您的内存创建一个小标头,该标头通常就在您分配的内存之前 - 即在稍微低几个字节的地址处。
释放内存时,它获取已释放的指针,返回几个字节,并检查描述实际分配内容的结构,包括已分配内容的大小。
运行时库将跟踪分配的内存块。给定由new
.
虽然这可以在操作系统本身(理论上)实现,但通常不是。操作系统跟踪的是分配给整个进程的页面,而不是在这个抽象级别分配的单个块。
它完全依赖于实现。就像您提到的常规 malloc()/free() 一样,系统必须保存一些额外的信息。一般来说,对 malloc() 或 new 运算符的调用会在它返回给您的指针之前在内存中设置一个头结构,以便稍后调用 free() 或 delete 运算符时它可以弄清楚发生了什么用你递给它的内存块。
它取决于实现,但我认为运行时库使用某种内存分配表来跟踪分配的块。