Gestione delle eccezioni in Objective-C
La gestione delle eccezioni è disponibile in Objective-C con la classe di base NSException.
La gestione delle eccezioni è implementata con i seguenti blocchi:
@try - Questo blocco tenta di eseguire una serie di istruzioni.
@catch - Questo blocco tenta di catturare l'eccezione nel blocco try.
@finally - Questo blocco contiene una serie di istruzioni che vengono sempre eseguite.
#import <Foundation/Foundation.h>
int main() {
NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init];
NSMutableArray *array = [[NSMutableArray alloc]init];
@try {
NSString *string = [array objectAtIndex:10];
} @catch (NSException *exception) {
NSLog(@"%@ ",exception.name);
NSLog(@"Reason: %@ ",exception.reason);
}
@finally {
NSLog(@"@@finaly Always Executes");
}
[pool drain];
return 0;
}
2013-09-29 14:36:05.547 Answers[809:303] NSRangeException
2013-09-29 14:36:05.548 Answers[809:303] Reason: *** -[__NSArrayM objectAtIndex:]: index 10 beyond bounds for empty array
2013-09-29 14:36:05.548 Answers[809:303] @finally Always Executes
Nel programma precedente, invece di terminare il programma a causa dell'eccezione, continua con il programma successivo poiché abbiamo utilizzato la gestione delle eccezioni.