• 迷途指针 new delete


    编程中有一种很难发现的错误是迷途指针。迷途指针也叫悬浮指针、失控指针,是党对一个指针进行delete操作后——这样会释放它所指向的内存——并没有把它设置为空时产生的。而后,如果你没有重新赋值就试图再次使用该指针,引起的结果是不可预料的。

    空指针和迷途指针的区别?

    当delete一个指针的时候,实际上仅是让编译器释放内存,但指针本身依然存在。这时它就是一个迷途指针。

    当使用以下语句时,可以把迷途指针改为空指针:

    myPtr=0;

    通常,如果在删除一个指针后又把它删除一次,程序就会变得非常不稳定,任何情况都有可能发生。但是如果你只是删除了一个空指针,则什么事都不会发生,这样做非常安全。

    使用迷途指针或空指针(如果myPtr=0)是非法的,而且有可能造成程序崩溃。如果指针是空指针,尽管同样是崩溃,但它同迷途指针的崩溃相比是一种可预料的崩溃。这样调试起来会方便得多。

    例如,

    #include<iostream>
    #include<new>
    using namespace std;
    
    typedef unsigned short  int USHORT;
    
    int main()
    {
        USHORT *pInt=new USHORT;
        *pInt=10;
        cout<<*pInt<<endl;
        delete pInt;
        //pInt=0;
        long *pLong=new long;
        *pLong=90000;
        cout<<"*Plong: "<<*pLong<<endl;
        *pInt=20;
        cout<<"*pInt: "<<*pInt<<endl;
        cout<<"*pLong: "<<*pLong<<endl;
        delete pLong;
    }

    此时运行结果:

    *pInt还是指向原来的内存,因此将pLong的数据修改了,但是结果是错误的而并没有保存。。

    加入将pInt=0;这句加上,此时运行结果直接报错,因为pInt指向空指针,不能访问空指针。

    C++中已经有了malloc/free,为什么还需要new/delete?

    malloc与free是C++/C语言的标准库函数,new/delete是C++的运算符。它们都可用于申请动态内存和释放内存。

    对于非内部数据类型的对象而言,光用malloc/free无法满足动态对象的要求。对象在创建的同时要自动执行构造函数,对象在消亡之前要自动执行析构函数。由于malloc/free是库函数而不是运算符,不在编译器控制权限之内,不能够把执行构造函数和析构函数的任何强加于malloc/free。

    因此C++语言需要一个能完成动态内存分配和初始化工作的运算符new,以及一个能完成清理和释放内存工作的运算符delete。new/delete不是库函数,而是运算符。

  • 相关阅读:
    Qt对文件的删除、复制、移动、可执行文件位置
    qt关于窗口关闭触发函数/信号
    QString.toUtf8().data()的问题 & char *转换到QByteArray注意
    Qt中类型之间的转换
    C++中auto和decltype的区别和功能
    Delphi 系统[11]关键字和保留字 goto、label
    Delphi 系统[10]关键字和保留字 with
    Delphi 系统[9]关键字和保留字 for、to、downto、do、while、repeat、until
    Delphi 系统[8]关键字和保留字 if、then、else、case
    Delphi 系统[7]关键字和保留字 begin、end
  • 原文地址:https://www.cnblogs.com/wuchanming/p/4310719.html
Copyright © 2020-2023  润新知