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.