Ошибка - [выпуск NSIndexPath]: сообщение отправлено освобожденному экземпляру 0x6a9d790 - PullRequest
0 голосов
/ 21 января 2012

Я создаю tableView с моими пользовательскими ячейками.здесь код ячейки .h файла

@interface ZUITableViewCell : UITableViewCell {
    IBOutlet UITextField *_textFieldOutlet;
    IBOutlet UILabel *_textLabelOutlet;

}
@property (retain, nonatomic) IBOutlet UITextField *_textFieldOutlet;
@property (retain, nonatomic) IBOutlet UILabel *_textLabelOutlet;

@end

И в моем файле контроллера табличного представления я создаю

#import <UIKit/UIKit.h>
#import "ZUITableViewCell.h"

@protocol ZUITableViewControllerDelegate  ///for main view controller

-(void) doneButtonPressed;

@end

@interface ZUITableViewController : UITableViewController {
    id <ZUITableViewControllerDelegate> delegate;

    NSMutableArray *menuItems;
    BOOL isAddingFields;
}

@property (nonatomic, retain) NSArray *menuItems;
@property (nonatomic, assign) id<ZUITableViewControllerDelegate> delegate;

- (CGRect) GetCellHegiht: (ZUITableViewCell *) cell;

@end

Я хочу добавить новые строки в мое табличное представление, когда пользователь выбираетвторой ряд.Для этого я опишу этот метод

- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{
    // Navigation logic may go here. Create and push another view controller.
    /*
     <#DetailViewController#> *detailViewController = [[<#DetailViewController#> alloc] initWithNibName:@"<#Nib name#>" bundle:nil];
     // ...
     // Pass the selected object to the new view controller.
     [self.navigationController pushViewController:detailViewController animated:YES];
     [detailViewController release];
     */
    NSLog (@"row = %d", indexPath.row);
    NSLog(@"INIT %p", self);
    ZUITableViewCell *cell = [tableView cellForRowAtIndexPath:indexPath];
    [cell._textFieldOutlet becomeFirstResponder];
     if (indexPath.row == 1 && isAddingFields == FALSE) {
         isAddingFields = TRUE;
         [menuItems insertObject:@"CC" atIndex:1];
         [menuItems insertObject:@"BCC" atIndex:2];

         NSIndexPath *path1 = [NSIndexPath indexPathForRow:1 inSection:0];
         NSIndexPath *path2 = [NSIndexPath indexPathForRow:2 inSection:0];
         NSArray *indexArray = [NSArray arrayWithObjects:path1,path2,nil];
         [tableView insertRowsAtIndexPaths:indexArray withRowAnimation:UITableViewRowAnimationTop];
         [tableView reloadRowsAtIndexPaths:[NSArray arrayWithObject:indexPath] withRowAnimation:UITableViewRowAnimationFade];

         [path1 release];
         [path2 release];

         [cell._textFieldOutlet becomeFirstResponder];
     }
}

и у меня есть метод cellForRowAtIndexPath

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
    static NSString *CellIdentifier = @"Cell";
    NSLog(@"INIT %p", self);
    NSLog (@"cell for row = %d", indexPath.row);
    ZUITableViewCell *cell = (ZUITableViewCell *)[tableView dequeueReusableCellWithIdentifier:CellIdentifier];
    if (cell == nil) {
        NSArray *topLevelsObjects = [[NSBundle mainBundle] loadNibNamed:@"ZUITableViewCell" owner:nil options:nil];
        for (id currentObject in topLevelsObjects){
            if ([currentObject  isKindOfClass:[UITableViewCell class]]){
                cell = (ZUITableViewCell *) currentObject;
                break;
            }
        }
    }
    if (indexPath.row == 3 && isAddingFields == FALSE){
       // [cell setBounds:[self GetCellHegiht:cell]];
    }
    cell.selectionStyle = UITableViewCellSelectionStyleNone;
    cell._textLabelOutlet.text = [menuItems objectAtIndex:indexPath.row];
    cell._textFieldOutlet.tag = indexPath.row;
    [cell._textFieldOutlet setEnabled:YES];
    if(indexPath.row == 0){
        [cell._textFieldOutlet becomeFirstResponder];
    }


    return cell;
}

В режиме отладки, как я вижу после нажатия на строку с indexPath.row == 1этот контроллер вызывает метод cellForRowAtIndexPath два раза с indexPath.row = 1 и 2. Но после него контроллер снова вызывает метод

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
//#warning Incomplete method implementation.
    return [menuItems count];
}

и вызовет метод cellForRowAtIndexPath тоже, после того, как программа примет мне эту ошибку (я включаю зомби) Ошибка- [NSIndexPath release]: сообщение отправлено освобожденному экземпляру 0x6a9d790

1 Ответ

1 голос
/ 21 января 2012

Метод [NSIndexPath indexPathForRow:inSection:] (используется в path1 и path2) возвращает объект с автоматическим освобождением, нет необходимости вызывать release после.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...