iOS开发中NSAssert()使用

今天在写代码的时候看别人写的代码 看到了他们写了

NSAssert(self.dataSource,@”BHBCenterView`s dataSource was nil.”);

于是就查了一些关于NSAssert的资料 记录一下

NSAssert()只是一个宏

用于开发阶段调试程序中的Bug,通过为NSAssert()传递条件表达式来断定是否属于Bug,满足条件返回真值,程序继续运行,如果返回假值,则抛出异常,并切可以自定义异常描述。NSAssert()是这样定义的:

#define NSAssert(condition, desc)

condition是条件表达式,值为YES或NO;desc为异常描述,通常为NSString。当conditon为YES时程序继续运行,为NO时,则抛出带有desc描述的异常信息。

生成一个LotteryEntry对象时,传入的NSDate不能为nil,加入NSAssert()判断。对象初始化源码如下:

– (id)initWithEntryDate:(NSDate*)theDate {

self= [superinit];

if(self) {

NSAssert(theDate !=nil,@”Argument must be non-nil”);

entryDate= theDate;

firstNumber= (int)random() %100+1;

secondNumber= (int)random() %100+1;

}

returnself;

}

接下来则是生成对象时传入一个值为nil的NSDate,看断言是否运行。

LotteryEntry*nilEntry = [[LotteryEntryalloc]initWithEntryDate:nil];

断言效果如下 运行程序会抛出异常:

2013-01-17 20:49:12.486 lottery[3951:303] *** Terminating app due to uncaught exception ‘NSInternalInconsistencyException’, reason: ‘Argument must be non-nil’

*** First throw call stack:

(

0CoreFoundation0x00007fff90c590a6 __exceptionPreprocess + 198

1libobjc.A.dylib0x00007fff8fd2a3f0 objc_exception_throw + 43

2CoreFoundation0x00007fff90c58ee8 +[NSException raise:format:arguments:] + 104

3Foundation0x00007fff88dae6a2 -[NSAssertionHandler handleFailureInMethod:object:file:lineNumber:description:] + 189

4lottery0x0000000100001929 -[LotteryEntry initWithEntryDate:] + 249

5lottery0x0000000100001794 main + 932

6libdyld.dylib0x00007fff8d83f7e1 start + 0

)

libc++abi.dylib: terminate called throwing an exception

转自使用断言NSAssert()调试程序错误

通过上面的NSAssert()的报错,很容易就能确定错误发生的原因及位置。

就是

*** Terminating app due to uncaught exception ‘NSInternalInconsistencyException’, reason: ‘Argument must be non-nil’


我们也可以设置断言只在debug的时候打印

设置方法:在Build Settings菜单,找到Preprocessor Macros项,Preprocessor Macros项下面有一个选择,用于程序生成配置:Debug版和Release版。选择 Release项,设置NS_BLOCK_ASSERTIONS,不进行断言检查。

    原文作者:CoderSJun
    原文地址: https://www.jianshu.com/p/369c9856be68
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞