内存分配失败错误处理

本文详细介绍了C语言中malloc/calloc/realloc/valloc/alloca/memalign等内存分配函数的特点及其错误处理方法,并对比了C++中new操作符在内存分配失败时的行为差异,包括异常处理和抑制异常两种方式。
摘要由CSDN通过智能技术生成

一、C语言中的malloc/calloc/realloc/valloc/alloca/memalign函数:

这样的内存分配函数在内存分配失败时都返回空指针因此在调用返回时检查返回值的方法比较简单只需要与空指针比较即可

:

char* p = (char*)malloc(1204)

if(p == NULL)

{

//error handle

}

char* pp = (char*)calloc(31024)

if(pp == NULL)

{

//error handle

}

二、C++中的new操作符:

C++中的new操作符在分配内存失败时默认的操作是抛出一个内置的异常而并不是直接返回空指针这样的话再把返回值与空指针比较就没有什么意义了因为C++抛出异常之后就直接跳出new操作符所在的那一行代码而不再执行后续的代码行了所以对new操作符返回值的判断代码就执行不到了当然标准C++也提供了抑制抛出异常的方法使之不再排除内存分配失败的异常转而直接返回空指针这是因为比较古老的编译器里面可能没有异常处理机制不能捕获到异常:

int* p = new int[SIZE]

if(p == 0) //检查p是否是空指针这个判断没有意义

{

return -1

}

所以在C++中有两种方法来处理new操作符分配内存失败的错误

1、通过捕获new操作符抛出的异常:

char* p = NULL

try

{

p = new char[1024]

}

catch(const std::bad_alloc& ex)

{

//exception handle

return -1

}

2、抑制异常的抛出:

char* p = NULL

p = new(std::nothrow)char[1024] //这样的话如果new分配内存失败就不会再抛出异常而是返回空指针了

if(p == NULL)                    //这样的判断就有意义了

{

//error handle

return -1

}

原文:

http://blog.csdn.net/app_12062011/article/details/7302673

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值