Search code examples
iosobjective-cuitableviewnsrangeexception

Terminating app due to uncaught exception 'NSRangeException', reason: '*** -[__NSArrayM objectAtIndex:]: index 0 beyond bounds for empty array


So I have a UITableView, and the app crashes with this error every time that the array does not have any items in it. What is strange is that I have another table that does not crash when it has zero objects in the array, and I am using almost identical code for each. Here is what I have:

@implementation FindFBFriendsViewController {
    NSMutableArray *friends;
}

- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view.
    UserFBFriends *fbFriends = [UserFBFriends sharedInstance];
    NSLog(@"Hell0 from the fbfriends view, array is %@", fbFriends.userFriends);
    friends = [[NSMutableArray alloc] initWithArray:fbFriends.userFriends];

    IndFBFriend *testFriend = [friends objectAtIndex:0];
    NSLog(@"USER Friends:    %@", testFriend.fullName);
}

-(void)viewWillAppear:(BOOL)animated {
    [self.fbTableView reloadData];
}

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {
    return [friends count];
}

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
     FBFriendCell *cell = [tableView dequeueReusableCellWithIdentifier:@"friendCell" forIndexPath:indexPath];

    if (cell == nil) {
        NSArray *nib = [[NSBundle mainBundle] loadNibNamed:@"FBFriendCell" owner:self options:nil];
        cell = [nib objectAtIndex:0];
    }

    IndFBFriend *indexRowFriend = [friends objectAtIndex:indexPath.row];
    [cell updateCellWithName:indexRowFriend.fullName profilePicture:indexRowFriend.profPic personFBId:indexRowFriend.fbId];

    cell.backgroundColor = [UIColor clearColor];
    return cell;
}

Here is the stack:

Terminating app due to uncaught exception 'NSRangeException', reason: '*** -[__NSArrayM objectAtIndex:]: index 0 beyond bounds for empty array'
*** First throw call stack:
(
    0   CoreFoundation                      0x0000000106213d85 __exceptionPreprocess + 165
    1   libobjc.A.dylib                     0x000000010597adeb objc_exception_throw + 48
    2   CoreFoundation                      0x00000001060f1804 -[__NSArrayM objectAtIndex:] + 212
    3   gif-wrap                            0x000000010338dd24 -[FindFBFriendsViewController viewDidLoad] + 340
    4   UIKit                               0x000000010421b984 -[UIViewController loadViewIfRequired] + 1198
    5   UIKit                               0x000000010422193b -[UIViewController __viewWillAppear:] + 120
    6   UIKit                               0x0000000104251750 -[UINavigationController _startCustomTransition:] + 1203
    7   UIKit                               0x0000000104261b9b -[UINavigationController _startDeferredTransitionIfNeeded:] + 712
    8   UIKit                               0x0000000104262d0b -[UINavigationController __viewWillLayoutSubviews] + 57
    9   UIKit                               0x0000000104411503 -[UILayoutContainerView layoutSubviews] + 248
    10  UIKit                               0x000000010413b980 -[UIView(CALayerDelegate) layoutSublayersOfLayer:] + 703
    11  QuartzCore                          0x0000000109754c00 -[CALayer layoutSublayers] + 146
    12  QuartzCore                          0x000000010974908e _ZN2CA5Layer16layout_if_neededEPNS_11TransactionE + 366
    13  QuartzCore                          0x0000000109748f0c _ZN2CA5Layer28layout_and_display_if_neededEPNS_11TransactionE + 24
    14  QuartzCore                          0x000000010973d3c9 _ZN2CA7Context18commit_transactionEPNS_11TransactionE + 277
    15  QuartzCore                          0x000000010976b086 _ZN2CA11Transaction6commitEv + 486
    16  UIKit                               0x000000010407b72e _UIApplicationHandleEventQueue + 7135
    17  CoreFoundation                      0x0000000106139301 __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE0_PERFORM_FUNCTION__ + 17
    18  CoreFoundation                      0x000000010612f22c __CFRunLoopDoSources0 + 556
    19  CoreFoundation                      0x000000010612e6e3 __CFRunLoopRun + 867
    20  CoreFoundation                      0x000000010612e0f8 CFRunLoopRunSpecific + 488
    21  GraphicsServices                    0x0000000109204ad2 GSEventRunModal + 161
    22  UIKit                               0x0000000104080f09 UIApplicationMain + 171
    23  gif-wrap                            0x00000001033922ef main + 111
    24  libdyld.dylib                       0x000000010752892d start + 1
    25  ???                                 0x0000000000000001 0x0 + 1
)
libc++abi.dylib: terminating with uncaught exception of type NSException

Does anybody know how I can solve this issue?


Solution

  • You say yourself that this happens when the friends array is empty. What do you expect to see when you run the following:

    IndFBFriend *testFriend = [friends objectAtIndex:0];
    

    -[NSArray objectAtIndex:] throws an exception when you access an index that does not exist; when friends is empty, that's what you see. Index 0 is invalid for an empty array.

    You haven't posted your other code, but I'm guessing that your other code does not contain a line like this, so it does not crash.