使用斷言NSAssert()調試程序錯誤


NSAssert()只是一個宏,用於開發階段調試程序中的Bug,通過為NSAssert()傳遞條件表達式來斷定是否屬於Bug,滿足條件返回真值,程序繼續運行,如果返回假值,則拋出異常,並切可以自定義異常描述。NSAssert()是這樣定義的:

#define NSAssert(condition, desc)

condition是條件表達式,值為YES或NO;desc為異常描述,通常為NSString。當conditon為YES時程序繼續運行,為NO時,則拋出帶有desc描述的異常信息。NSAssert()可以出現在程序的任何一個位置。具體事例如下:

生成一個LotteryEntry對象時,傳入的NSDate不能為nil,加入NSAssert()判斷。對象初始化源碼如下:

 

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

    self = [super init];

    if (self) {

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

        entryDate = theDate;

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

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

    }

    return  self;

}

接下來則是生成對象時傳入一個值為nil的NSDate,看斷言是否運行。

 

LotteryEntry *nilEntry = [[LotteryEntry allocinitWithEntryDate: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:

(

0   CoreFoundation                      0x00007fff90c590a6 __exceptionPreprocess + 198

1   libobjc.A.dylib                     0x00007fff8fd2a3f0 objc_exception_throw + 43

2   CoreFoundation                      0x00007fff90c58ee8 +[NSException raise:format:arguments:] + 104

3   Foundation                          0x00007fff88dae6a2 -[NSAssertionHandler handleFailureInMethod:object:file:lineNumber:description:] + 189

4   lottery                             0x0000000100001929 -[LotteryEntry initWithEntryDate:] + 249

5   lottery                             0x0000000100001794 main + 932

6   libdyld.dylib                       0x00007fff8d83f7e1 start + 0

)

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

 

轉:http://blog.sina.com.cn/s/blog_75992b660101kbj2.html


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2026 CODEPRJ.COM