zoukankan      html  css  js  c++  java
  • C/C++中内存泄漏、内存溢出与野指针的解释与说明

    1、内存泄漏

    内存泄漏是指我们在堆中申请(new/malloc)了一块内存,但是没有去手动的释放(delete/free)内存,导致指针已经消失,而指针指向的东西还在,已经不能控制这块内存,

    所以就是内存泄漏了,看下面的例子。

    void remodel(std::string &str)
    {
        std::string *ps = new std::string(str);  //创建了一个局部指针变量,函数调用结束后,指针变量消失,但堆中内存仍然被占用,没有被释放,导致内存泄漏
        //内存泄漏了
    }
    使用完这个变量之后却没有及时回收这部分内存,这时我们就说发生了内存泄露。如果发生了内存泄露又没有及时发现,随着程序运行时间的增加,程序越来越大,直到消耗完系统的所有内存,然后系统崩溃。
    (转载自:https://blog.csdn.net/zhanghuaichao/article/details/52982687 )

    2、内存溢出

    内存溢出 out of memory,是指程序在申请内存时,没有足够的内存空间供其使用,出现out of memory;比如申请了一个integer,但给它存了long才能存下的数,那就是内存溢出

    3、野指针
    指向一个已删除的对象或未申请访问受限内存区域的指针。与空指针不同,野指针无法通过简单地判断是否为 NULL避免,而只能通过养成良好的编程习惯来尽力减少。对野指针进行操作很容易造成程序错误。
    a.指针变量未初始化
    任何指针变量刚被创建时不会自动成为NULL指针,它的缺省值是随机的,它会乱指一气。所以,指针变量在创建的同时应当被初始化,要么将指针设置为NULL,要么让它指向合法的内存。

    b.野指针指针释放后之后未置空
    有时指针在free或delete后未赋值 NULL,便会使人以为是合法的。别看free和delete的名字(尤其是delete),它们只是把指针所指的内存给释放掉,但并没有把指针本身干掉。此时指针指向的就是“垃圾”内存。释放后的指针应立即将指针置为NULL,防止产生“野指针”。

    c.野指针指针操作超越变量作用域
    不要返回指向栈内存的指针或引用,因为栈内存在函数结束时会被释放。示例程序如下:
    class A {
    public:
      void Func(void){ cout << “Func of class A” << endl; }
    };
    class B {
    public:
      A *p;
      void Test(void) {
        A a;
        p = &a; // 注意 a 的生命期 ,只在这个函数Test中,而不是整个class B
      }
      void Test1() {
      p->Func(); // p 是“野指针”
      }
    };

    由于a的生命周期是在void Test(void)函数结束时就应该被释放,所以你再引用指针p的时候它指向的内存已经被释放了,所以p已经是野指针了。

    (转载自:https://blog.csdn.net/zhanghuaichao/article/details/52982687 )


  • 相关阅读:
    (第二天)原型、继承
    (第一天)包装对象、作用域、创建对象
    你欺骗了我,可选参数必须位于所有参数最后
    反射之动态创建对象
    异步编程
    前端性能优化方法
    性能瓶颈分析方法
    性能测试应用领域
    <转>jmeter(十五)函数助手
    正则表达式基础知识
  • 原文地址:https://www.cnblogs.com/goahead--linux/p/11049692.html
Copyright © 2011-2022 走看看