Search code examples
iphoneobjective-cuitableviewsdkipod

Crash on UITableView when scrolling


I'm developing a little text editor and I started using the Table View template, added code for listing on it the contents of the app Documents directory, and all is OK, I copied some files to the directory and the table view shows them, but when I start scrolling, it crashes. I think that something is being released when it doesn't have to. Here I left the code and the crash log :)

RootViewController.m

    NSFileManager *directoryContent;
- (void)viewWillAppear:(BOOL)animated {
    [super viewWillAppear:animated];
    [self listDumpFiles];
}
// Customize the number of sections in the table view.
- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView {
    return 1;
}


// Customize the number of rows in the table view.
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {
    return [directoryContent count];
}


// Customize the appearance of table view cells.
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {

    static NSString *CellIdentifier = @"Cell";

    UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];
    if (cell == nil) {
        cell = [[[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:CellIdentifier] autorelease];
    }

    // Configure the cell.
    cell.text = [directoryContent objectAtIndex:indexPath.row];
    return cell;
}
- (void)listDumpFiles {
    NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
    NSString *documentsDirectory = [paths objectAtIndex:0];

    directoryContent = [[NSFileManager defaultManager] directoryContentsAtPath: documentsDirectory];

    NSLog(@"%@", documentsDirectory);
    return;
}

Crash log

2011-02-03 17:38:16.516 uNotes[15352:40b] /Users/pablo/Library/Application Support/iPhone Simulator/4.2/Applications/DF298F31-5723-4A1E-9EAA-3353C34BDCB2/Documents
2011-02-03 17:38:17.412 uNotes[15352:40b] -[NSCFString objectAtIndex:]: unrecognized selector sent to instance 0x9b243f0
2011-02-03 17:38:17.413 uNotes[15352:40b] *** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '-[NSCFString objectAtIndex:]: unrecognized selector sent to instance 0x9b243f0'
*** Call stack at first throw:
(
    0   CoreFoundation                      0x00da7be9 __exceptionPreprocess + 185
    1   libobjc.A.dylib                     0x00efc5c2 objc_exception_throw + 47
    2   CoreFoundation                      0x00da96fb -[NSObject(NSObject) doesNotRecognizeSelector:] + 187
    3   CoreFoundation                      0x00d19366 ___forwarding___ + 966
    4   CoreFoundation                      0x00d18f22 _CF_forwarding_prep_0 + 50
    5   uNotes                              0x0000238c -[RootViewController tableView:cellForRowAtIndexPath:] + 216
    6   UIKit                               0x003247fa -[UITableView(UITableViewInternal) _createPreparedCellForGlobalRow:withIndexPath:] + 634
    7   UIKit                               0x0031a77f -[UITableView(UITableViewInternal) _createPreparedCellForGlobalRow:] + 75
    8   UIKit                               0x0032f450 -[UITableView(_UITableViewPrivate) _updateVisibleCellsNow:] + 1561
    9   UIKit                               0x00327538 -[UITableView layoutSubviews] + 242
    10  QuartzCore                          0x01c65451 -[CALayer layoutSublayers] + 181
    11  QuartzCore                          0x01c6517c CALayerLayoutIfNeeded + 220
    12  QuartzCore                          0x01c5e37c _ZN2CA7Context18commit_transactionEPNS_11TransactionE + 310
    13  QuartzCore                          0x01c5e0d0 _ZN2CA11Transaction6commitEv + 292
    14  QuartzCore                          0x01c8e7d5 _ZN2CA11Transaction17observer_callbackEP19__CFRunLoopObservermPv + 99
    15  CoreFoundation                      0x00d88fbb __CFRUNLOOP_IS_CALLING_OUT_TO_AN_OBSERVER_CALLBACK_FUNCTION__ + 27
    16  CoreFoundation                      0x00d1e0e7 __CFRunLoopDoObservers + 295
    17  CoreFoundation                      0x00ce6bd7 __CFRunLoopRun + 1575
    18  CoreFoundation                      0x00ce6240 CFRunLoopRunSpecific + 208
    19  CoreFoundation                      0x00ce6161 CFRunLoopRunInMode + 97
    20  GraphicsServices                    0x016dc268 GSEventRunModal + 217
    21  GraphicsServices                    0x016dc32d GSEventRun + 115
    22  UIKit                               0x002bf42e UIApplicationMain + 1160
    23  uNotes                              0x00001fc0 main + 102
    24  uNotes                              0x00001f51 start + 53
)
terminate called after throwing an instance of 'NSException'
Program received signal:  “SIGABRT”.
(gdb) 

Solution

  • According to the stack trace you are attempting to call objectAtIndex: on a String. Probably a memory management issue. Enable zombies to get more information about the object it is being called on.

    UPDATE

    It is probably this line

    directoryContent = [[NSFileManager defaultManager] directoryContentsAtPath: documentsDirectory];

    I think directoryContentsAtPath: returns an autoreleased object. If you have directoryContent set up as a @property(nonatomic, retain) in your header you can set it using self.directoryContent = [[NSFileManager defaultManager] directoryContentsAtPath: documentsDirectory]; and it will automatically retain the object returned by NSFileManager, otherwise you could call directoryContent = [[[NSFileManager defaultManager] directoryContentsAtPath: documentsDirectory] retain]; but be sure to release that object when you no longer need it.