用指针正确的操纵动态数组与正确用delete释放内存的方法

本文深入探讨了C++中使用指针操纵动态数组时的常见问题,特别是如何正确处理内存释放,避免内存泄漏导致的程序崩溃。通过实例分析,展示了不当的操作可能导致的内存访问错误,并提供了安全释放内存的正确方法。

开发板推荐:天空星STM32F407VET6开发板

超高性价比 STM32主控 | 超高主频 | 一板兼容百芯 | 比赛神器 | 沉金彩色丝印

#include<iostream>

#include<cassert>

using namespace std;

void f(int *i_ptr,size_t n)

{

    assert(n>0);

    for(int i=0;i<n;++i)

        *(i_ptr++)=i;

}

int main()

{

    size_t array_size=10;

    int *array_ptr=new int[array_size];

    f(array_ptr,array_size);

    for(int i=0;i<array_size;++i)

        cout<<*(array_ptr++)<<endl; //A

        //cout<<array_ptr[i]<<endl;

    delete []array_ptr;  //B

    return EXIT_SUCCESS;

}

用指针可以操纵数组,然而不正确的操作与不正确的释放却会造成程序崩溃。

本段代码奔溃了,问题出在哪里呢?

让我想想。。。。。。。。。。。。。。。

十分钟后。。。。。。。。。。。。。。。

二十分钟后。。。。。。。。。。。。。。


好了,想不出来。。。。。。。。。。。。。

其实,为题就在
            
delete []array_ptr;

释放的方法没错(语法上),但是错误的。


因为
    for(int i=0;i<array_size;++i)
        cout<<*(array_ptr++)<<endl; //A
此时的array_ptr已经指向了一个超出末尾的地方
也就是array_ptr[10],但该内存是越界的,而且后面还大胆用
delete []array_ptr;
来释放不存在的东西,当然运行崩溃。

总结,虽然通过new来建立动态数组,用delete[]来释放是标准做法,但是如果不注意指针此时的实际指向,则非常容易造成内存泄露或者越界,程序当然奔溃。




呜呜~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
那该怎么办???????????????

很好办。。

int main()
{
    size_t array_size=10;
    int *array_ptr=new int[array_size];
    int *del_array_ptr=array_ptr;
    f(array_ptr,array_size);
    for(int i=0;i<array_size;++i)
        cout<<*(array_ptr++)<<endl;
        //cout<<array_ptr[i]<<endl;
    delete []del_array_ptr;
    return EXIT_SUCCESS;
}

然而下面的代码也是可以编译运行的
int main()
{
    size_t array_size=10;
    int *array_ptr=new int[array_size];
    int *del_array_ptr=array_ptr;
    f(array_ptr,array_size);
    for(int i=0;i<array_size;++i)
        cout<<*(array_ptr++)<<endl;
        //cout<<array_ptr[i]<<endl;
    delete del_array_ptr;    //可以运行,但是错误的,因为该操作实际上释放了数组的第一个元素所占用的内存,剩下的九个元素都没有释放,造成内存泄露。
    return EXIT_SUCCESS;
}



开发板推荐:天空星STM32F407VET6开发板

超高性价比 STM32主控 | 超高主频 | 一板兼容百芯 | 比赛神器 | 沉金彩色丝印

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值