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

#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;
}



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值