• 63、new和delete的实现原理, delete是如何知道释放内存的大小的额?


    1、 new简单类型直接调用operator new分配内存;

    而对于复杂结构,先调用operator new分配内存,然后在分配的内存上调用构造函数;

    对于简单类型,new[]计算好大小后调用operator new;

    对于复杂数据结构,new[]先调用operator new[]分配内存,然后在p的前四个字节写入数组大小n,然 后调用n次构造函数,针对复杂类型,new[]会额外存储数组大小;

    ① new表达式调用一个名为operator new(operator new[])函数,分配一块足够大的、原始的、未命 名的内存空间;

    ② 编译器运行相应的构造函数以构造这些对象,并为其传入初始值;

    ③ 对象被分配了空间并构造完成,返回一个指向该对象的指针。

    2、 delete简单数据类型默认只是调用free函数;复杂数据类型先调用析构函数再调用operator delete;针对简单类型,delete和delete[]等同。假设指针p指向new[]分配的内存。因为要4字节存储数 组大小,实际分配的内存地址为[p-4],系统记录的也是这个地址。delete[]实际释放的就是p-4指向的内 存。而delete会直接释放p指向的内存,这个内存根本没有被系统记录,所以会崩溃。

    3、 需要在 new [] 一个对象数组时,需要保存数组的维度,C++ 的做法是在分配数组空间时多分配了 4 个字节的大小,专门保存数组的大小,在 delete [] 时就可以取出这个保存的数,就知道了需要调用析 构函数多少次了。

  • 相关阅读:
    几种比较好看的颜色代码
    浅谈Express的put与del
    关于Linux软连接
    logstash根据日志关键词报警
    linux历史命令审计
    showdoc升级问题,showdoc错误日志
    以Docker容器的形式运行GVM-11
    主机标准化配置文档
    网络设备标准化配置文档
    Zabbix日常监控之lvs监控
  • 原文地址:https://www.cnblogs.com/crbhf/p/14970560.html
Copyright © 2020-2023  润新知