Нажатие кнопки UIAlertView вызывает сбой, когда все остальные работают нормально - PullRequest
3 голосов
/ 04 марта 2010

У меня есть просмотр предупреждений, который отображается нормально. В своем заголовке я включил UIAlertViewDelegate, но по какой-то причине всякий раз, когда я нажимаю кнопку в представлении предупреждений, мое приложение вылетает с плохим превышением, говоря, что был отправлен нераспознанный селектор.

Любые идеи будут полезны. У меня точно такой же код работает в других классах без каких-либо проблем.

Вот мой код:

    -(void)deletePatient
{
 NSLog(@"Delete");
 //Patient *patientInRow = (Patient *)[[self fetchedResultsController] objectAtIndexPath:cellAtIndexPath];
 NSMutableArray *visitsArray = [[NSMutableArray alloc] initWithArray:[patient.patientsVisits allObjects]];
 //cellAtIndexPath = indexPath;
 int visitsCount = [visitsArray count];
 NSLog(@"Visit count is %i", visitsCount);
 if (visitsCount !=0) 
 {
  //Display AlertView
  NSString *alertString = [NSString stringWithFormat:@"Would you like to delete %@'s data and all their visits and notes?", patient.nameGiven];
  UIAlertView *alert1 = [[UIAlertView alloc] initWithTitle:alertString message:nil delegate:self cancelButtonTitle:@"Yes" otherButtonTitles:@"No",nil];
  [alert1 show];
  [alert1 release];

 }
 else if (visitsCount ==0) 
 {
  //Do something else
 }

 [visitsArray release];

}

-(void)alertView:(UIAlertView*)alertView clickedButtonAtIndex:(NSInteger)buttonIndex
{
 // the user clicked one of the OK/Cancel buttons
 if (buttonIndex == 0)
 {
  NSLog(@"Yes");

 }
 else
 {
  NSLog(@"No");
 }
}

Так что, насколько я могу понять, это связано с тем фактом, что я вызываю метод deletePatient из моего подкласса UITableViewCell и передаю объект пациента, как и я. Вот код для его передачи

-(IBAction)deletePatient:(id)sender
{
    NSLog(@"Delete Patient:%@",patient.nameGiven);
    PatientListTableViewController *patientList = [[PatientListTableViewController alloc] init];
    patientList.patient = patient;
    UITableView *tableView = (UITableView *)[self superview];
    tableView.scrollEnabled = YES;
    [patientList deletePatient];
    menuView.center = CGPointMake(160,menuView.center.y);
    [patientList release];
}

Ответы [ 3 ]

8 голосов
/ 04 марта 2010

Вы устанавливаете объект PatientList в качестве делегата экземпляра UIAlertView, а затем освобождаете его.Когда пользователь щелкает кнопку оповещения, он вызывает [делегат alertView: self clickedButtonAtIndex: buttonIndex], но делегат PatientList уже освобожден и больше не существует.Переменная делегат на данный момент содержит мусор, поэтому не удивительно, что у нее нет alertView: clickedButtonAtIndex: selector;

Просто освободите объект PatientList в оповещении alertView: clickedButtonAtIndex: методили создайте / освободите PatientList при создании / освобождении внешнего класса или просто используйте свойство:

// в * .h файле:

...
PatientListTableViewController *patientList;
...
@property(retain) PatientListTableViewController *patientList;
...

// в * .m файле:@synthesize PatientList;

...
self.patientList =  [[PatientListTableViewController alloc] init];
0 голосов
/ 04 марта 2010

Попробуйте использовать UIAlerView в качестве объекта автоматического освобождения, как этот;

UIAlertView *alert1 = [[UIAlertView alloc] initWithTitle:alertString message:nil delegate:self cancelButtonTitle:@"Yes" otherButtonTitles:@"No",nil] autorelease];
[alert1 show];
0 голосов
/ 04 марта 2010

Все хорошо с кодом, который вы предоставили. Если с объектом пациента в другом месте не происходит что-то необычное, я бы сказал, что здесь все выглядит хорошо.

...