1.new和deleteC语言内存管理方式在C中可以继续使用但有些地方就无能为力而且使用起来比较麻烦因此C又提出了自己的内存管理方式通过new和delete操作符进行动态内存管理这里在动态申请和释放时一定要匹配使用但是我们发现即使我们随意使用程序也没有崩溃但是这些开辟的空间都是默认类型的我们接下来试一下开辟自定义类型的空间程序是否会崩溃我们运行程序发现直接就崩溃了那为什么自定义的类型就不可以随意使用释放内存的函数呢这就要探究mallocfree和newdelete的区别。我们先来看malloc和free然后再看new和delete2.new和delete在底层是怎么实现的2.1new底层的实现 我们先来new一个test类型的空间。然后运行起来我们转到反汇编代码看看总结new的实现就是调用operate newsize_t函数函数内部循坏调用malloc如果申请空间成功就返回如果申请失败就检测是否有应对措施如果提供就执行措施再继续malloc如果未提供就抛出异常。然后再调用构造函数将申请的内存初始化。2.2delete底层的实现 我们执行delete语句转到反汇编来进入不知名函数那么我们来看看operator deletevoid *pt函数是如何如何实现的总结delete 的实现就是先调用类中的析构函数将对象中的数据清空然后调用operator deletevoid *pt函数将内存释放掉。2.3new []底层的实现执行完这一系列操作后就会调用n次构造函数将对象构造成功总结new []就是调用operate new[]函数在operate new []中调用operate new函数执行刚刚的一系列操作然后返回申请的内存。再调用n次构造函数将申请的内存初始化。2.4delete []的实现总结delete函数就是先调用n次析构函数将申请的内存空间中的数据清空然后再调用operate delete函数将内存释放掉。3.重载new和delete既然有了new和delete这么好的申请内存的方法那我们为什么还要重新实现new和delete呢注意这里的重新实现实现new和delete并不是重新实现new和delete的申请内存的方式而是有时我们再debug版本下调试时需要一些打印输出一些信息这里我们需要再用new申请内存的时候要实现输出一些信息。比如说打印文件名调用函数调用行数等等。我们重新实现new将我们的文件信息调用函数调用行数都打印出来可以看到虽然将函数都打印出来了但是传参的时候需要传许多参数所以我们可以用宏替换的方式来解决但是我们需要这些信息都是在调试的时候才需要所以我们可以条件编译一下只在debug版本底下执行我们将delete实现重载注意这里如果我们将delete自己实现重载之后再调用delete重载函数是不会调用类中的析构函数的如果我们的对象中涉及了资源的申请那么就不会释放。4.定位new使用场景在有些场景下我们可能会申请一块内存空间但是这块内存空间并没有初始化当我们想要使用这块内存空间时想给他初始化对于类类型的对象我们想要给他初始化时只能调用构造函数初始化但是构造函数只能在创建时由编译器自动调用就像人不可以选择自己的出生时间那我们这时就要使用定位new来给已经申请号的内存中创建一个对象。