【C++】面试常问八股

5、内存管理

野指针
  • 野指针指的是未进行初始化未清零的指针,不是NULL指针
  • 野指针产生原因及解决方案:
    • 指针变量未初始化:指针变量定义时若未初始化,则其指向的地址是随机的,不为NULL;定义时初始化为NULL合法内存地址
    • 指针被free()或delete之后未置空(NULL):free()和delete将指针指向的内存释放掉(操作系统回收指针指向的内存区域),但是指针变量本身的值不会自动重置;释放内存后立即清空 / 使用智能指针。【if(p!=NULL)只能判断是否为显式空指针】
    • 指针操作超出了变量的作用范围:返回指向栈内存的指针是野指针,栈区内存(局部变量/函数参数)在函数结束时会被释放
内存泄漏
  • 程序在运行过程中,动态分配的堆内存(new)因未正确释放而无法被重新使用的现象。随着程序运行时间的增长,泄漏的内存会逐渐累积,最终可能导致系统可用内存耗尽、程序性能下降甚至崩溃。

  • 内存泄漏的原因:

    • 类的构造函数和析构函数中没有匹配的调用new和delete函数(对象生命周期内动态分配的资源未正确释放 ):
      • ①堆区创建对象占用内存,却未释放
      • ②类的构造函数中动态地分配了内存,但是析构函数未释放内存,或未正确释放内存
    • 浅拷贝导致重复释放或资源未释放:两个对象指向同一内存,析构时均尝试释放该内存,导致双重释放错误。
    c++ 复制代码
    class ShallowCopyClass {
    public:
        int* data;
        ShallowCopyClass(int val) { data = new int(val); }
        ~ShallowCopyClass() { delete data; }
        // 未定义拷贝构造函数,使用默认浅拷贝
    };
    
    ShallowCopyClass a(5);
    ShallowCopyClass b = a; // 浅拷贝,b.data 与 a.data 指向同一内存
    // 析构时,a 和 b 的析构函数均会 delete 同一内存,导致崩溃!
    • 基类析构函数未声明为虚函数:C++ 多态机制要求通过虚函数表动态绑定析构函数。若基类析构函数非虚,delete 基类指针时仅调用基类析构函数,子类析构逻辑被跳过;将基类析构函数声明为虚函数,确保子类析构链正确执行
    c++ 复制代码
    class Base {
    public:
        Base() { /* 基类资源分配 */ }
        ~Base() { /* 仅释放基类资源 */ } // 非虚析构
    };
    
    class Derived : public Base {
    public:
        int* derived_data;
        Derived() { derived_data = new int(10); }
        ~Derived() { delete derived_data; } // 不会被调用!
    };
    
    Base* obj = new Derived();
    delete obj; // 仅调用 Base::~Base(), Derived::~Derived() 未执行,derived_data 泄漏!
相关推荐
阿猿收手吧!14 分钟前
【C++】实现自旋锁:三种高效实现与实战指南
服务器·网络·c++
代码游侠35 分钟前
C语言核心概念复习(三)
开发语言·数据结构·c++·笔记·学习·算法
明洞日记42 分钟前
【软考每日一练030】软件维护:逆向工程与再工程的区别与联系
c++·软件工程·软考·逆向工程
郝学胜-神的一滴1 小时前
深入Linux网络编程:accept函数——连接请求的“摆渡人”
linux·服务器·开发语言·网络·c++·程序人生
茉莉玫瑰花茶1 小时前
C++ 17 详细特性解析(3)
开发语言·c++
C+-C资深大佬1 小时前
C++多态
java·jvm·c++
今儿敲了吗1 小时前
11| 子集
c++·笔记·算法
阿猿收手吧!1 小时前
【C++】无锁原子栈:CAS实现线程安全
开发语言·c++·安全
蒹葭玉树1 小时前
【C++上岸】C++常见面试题目--操作系统篇(第三十期)
c++·面试·risc-v
凤年徐1 小时前
容器适配器深度解析:从STL的stack、queue到优先队列的底层实现
开发语言·c++·算法