Я знаю, что эта проблема упоминалась ранее, но решения там не применяются. У меня UINavigationController со встроенным UITableViewController, настроенным с использованием IB. В IB делегат UITableView и dataSource оба установлены для моего происхождения UITableViewController. Этот класс был добавлен с использованием шаблонов XCode для классов UITableViewController. Пользовательского UITableViewCell не существует, и табличное представление использует простой стиль по умолчанию только с одним заголовком.
Что ж, в симуляторе список отображается правильно, с двумя элементами, предоставленными dataSource, поэтому dataSource связан правильно. Если я удалю ссылку выхода для источника данных в IB, вместо этого будет отображена пустая таблица.
Как только я нажимаю на один из этих двух элементов, он мигает синим, и GDB встречает прерывание в __forwarding__
в пределах UITableView::_selectRowAtIndexPath
. Это не достигает точки останова, установленной в моем непустом методе didSelectRowIndexPath. Я проверил аргументы и имя метода, чтобы исключить опечатки, приводящие к другому селектору.
Недавно мне не удалось установить, правильно ли установлен делегат, но так как он установлен эквивалентно источнику данных, который получает два элемента из одного класса, я ожидаю, что он будет установлен правильно. Итак, что не так?
Я использую iPhone / iPad SDK 3.1.2 ... но также пытался использовать iPhone SDK 3.1 в симуляторе.
РЕДАКТИРОВАТЬ: Это код моего происхождения UITableViewController:
#import "LocalBrowserListController.h"
#import "InstrumentDescriptor.h"
@implementation LocalBrowserListController
- (void)viewDidLoad {
[super viewDidLoad];
[self listLocalInstruments];
}
- (void)viewDidAppear:(BOOL)animated {
[super viewDidAppear:animated];
}
- (void)didReceiveMemoryWarning {
[super didReceiveMemoryWarning];
}
- (void)viewDidUnload {
[super viewDidUnload];
}
- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView {
return 1;
}
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {
return [entries count];
}
- (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];
if ( ( [entries count] > 0 ) && ( [indexPath length] > 0 ) )
cell.textLabel.text = [[[entries objectAtIndex:[indexPath indexAtPosition:[indexPath length] - 1]] label] retain];
return cell;
}
- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{
if ( ( [entries count] > 0 ) && ( [indexPath length] > 0 ) )
{
...
}
}
- (void)dealloc {
[super dealloc];
}
- (void) listLocalInstruments {
NSMutableArray *result = [NSMutableArray arrayWithCapacity:10];
[result addObject:[InstrumentDescriptor descriptorOn:[[NSBundle mainBundle] pathForResource:@"example" ofType:@"idl"] withLabel:@"Default 1"]];
[result addObject:[InstrumentDescriptor descriptorOn:[[NSBundle mainBundle] pathForResource:@"example" ofType:@"xml"] withLabel:@"Default 2"]];
[entries release];
entries = [[NSArray alloc] initWithArray:result];
}
@end