• malloc和new的本质区别


    目录

    一、结论

     二、示例

    1.实现类T

    2.用malloc分配类T的内存空间

    3.用new分配类T的内存空间


    一、结论

            malloc 和 new 都是用于在运行时动态分配内存的机制。但它们之间存在一些本质的区别,主要是在使用方面,现在我们直接说结论,然后在通过一个案例来理解和加深区别。

     

     二、示例

    1.实现类T

            我们先来创建一个类T,代码比较简单,主要有一个静态的成员变量count。count作用用来计算创建类T实例数量的多少。代码如下:

    1. class T
    2. {
    3. public:
    4. T()
    5. {
    6. a = 10;
    7. std::cout << "第" << ++count << "个T被构造了" << std::endl;
    8. }
    9. ~T()
    10. {
    11. std::cout << "第" << count-- << "个T被销毁了" << std::endl;
    12. }
    13. static int count;
    14. int a;
    15. };
    16. // 初始化静态变量count
    17. int T::count = 0;

             需要注意:静态成员变量需要在类外初始化!

    2.用malloc分配类T的内存空间

            我们用malloc关键字动态分配10个类T大小的空间,同时测试构造函数和析构函数是否发生变化。代码和结果如下:

    1. int main()
    2. {
    3. T* t1 = (T*)malloc(sizeof(T) * 10);
    4. std::cout << t1->count << std::endl;
    5. // 释放空间
    6. free(t1);
    7. }

            得出的结果count为0,同时构造函数和析构函数没有触发。可见malloc 只会分配请求的内存大小,并返回一个指向该内存的指针,它不会调用任何构造函数。

    3.用new分配类T的内存空间

            与malloc同样,我们用new关键字动态分配10个类T大小的空间,同时测试构造函数和析构函数是否发生变化。代码和结果如下:

    1. int main()
    2. {
    3. T* t2 = new T[10];
    4. std::cout << t2->count << std::endl;
    5. // 释放空间
    6. delete[] t2;
    7. }

             得出的结果count为10,同时构造函数和析构函数都会触发。所以new 不仅会分配内存,还会调用对象的构造函数(如果适用)。同样地,当使用 delete 运算符释放内存时,它会调用对象的析构函数。

  • 相关阅读:
    高并发系统设计
    01-简单字符串题目
    Microsoft 10/11 命令行打开系统设置页(WUAP,!WIN32)
    Kafka - 3.x Producer 生产者最佳实践
    【Java面试】Java反射优缺点
    RUST持续学习 一点borrow问题的心得记录
    Pytorch 常用函数
    alsa-lib和alsa-utils移植
    2022杭电多校(二)
    Android开发中关于Ui的语法糖
  • 原文地址:https://blog.csdn.net/m0_62681656/article/details/139786018