dequeueReusableCellWithIdentifier возвращает другую ячейку для одного и того же пути
0 incmiko [2018-04-26 17:05:00]
Я пытаюсь понять, что происходит не так, потому что когда я делаю обновление таблицы и вызываю cellForRowAtIndexPath, dequeueReusableCellWithIdentifier не возвращает ячейку, в которой я нуждаюсь.
Это просто обновление табличного представления с абсолютно одинаковым индексом, а dequeueReusableCellWithIdentifier возвращает nil в первый раз обновления и создает для него еще одну ячейку. Это плохо, потому что каждый метод обновления называется дважды, что вызывает мигание изображений
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
cell = [tableView dequeueReusableCellWithIdentifier:cellID];
if (cell == nil)
cell = [[cellClass alloc]initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:cellID];
if ([cellClass isEqual:[ATTimeLineMealCell class]]) {
NSLog(@"table view: %@",tableView);
NSLog(@"CELL DATA: %@",cell);
NSLog(@"Row: %ld , section: %ld",indexPath.row,indexPath.section);
}
}
- (void) tableView:(UITableView *)tableView willDisplayCell:(UITableViewCell *)cell forRowAtIndexPath:(NSIndexPath *)indexPath{
NSLog(@"table view: %@",tableView);
NSLog(@"CELL DATA UPDATE:%@",cell);
}
Поток: добавив новую ячейку, затем перезагрузите ячейку (а не перезагрузите)
И журнал:
> 2018-04-26 15:53:26.214828+0200 Ate[6956:2981607] table view:
> <ATQueryTableView: 0x10482a600; baseClass = UITableView; frame = (0 0;
> 375 667); clipsToBounds = YES; gestureRecognizers = <NSArray:
> 0x1c044f960>; layer = <CALayer: 0x1c00362a0>; contentOffset: {0,
> -292}; contentSize: {375, 747}; adjustedContentInset: {292, 0, 0, 0}> 2018-04-26 15:53:26.215271+0200 Ate[6956:2981607] CELL DATA:
> <ATTimeLineMealCell: 0x1040aa800; baseClass = UITableViewCell; frame =
> (0 0; 375 44); layer = <CALayer: 0x1c4437de0>> 2018-04-26
> 15:53:26.215290+0200 Ate[6956:2981607] Row: 1 , section: 0 2018-04-26
> 15:53:26.216296+0200 Ate[6956:2981607] table view: <ATQueryTableView:
> 0x10482a600; baseClass = UITableView; frame = (0 0; 375 667);
> clipsToBounds = YES; gestureRecognizers = <NSArray: 0x1c044f960>;
> layer = <CALayer: 0x1c00362a0>; contentOffset: {0, -292}; contentSize:
> {375, 747}; adjustedContentInset: {292, 0, 0, 0}> 2018-04-26
> 15:53:26.216409+0200 Ate[6956:2981607] CELL DATA
> UPDATE:<ATTimeLineMealCell: 0x1040aa800; baseClass = UITableViewCell;
> frame = (0 80; 375 120); autoresize = W; layer = <CALayer:
> 0x1c4437de0>>
>
> 2018-04-26 15:53:28.456177+0200 Ate[6956:2981607] table view:
> <ATQueryTableView: 0x10482a600; baseClass = UITableView; frame = (0 0;
> 375 667); clipsToBounds = YES; gestureRecognizers = <NSArray:
> 0x1c044f960>; layer = <CALayer: 0x1c00362a0>; contentOffset: {0, 80};
> contentSize: {375, 747}; adjustedContentInset: {315, 0, 0, 0}>
> 2018-04-26 15:53:28.456308+0200 Ate[6956:2981607] CELL DATA:
> <ATTimeLineMealCell: 0x104162a00; baseClass = UITableViewCell; frame =
> (0 0; 375 44); layer = <CALayer: 0x1c4437bc0>> 2018-04-26
> 15:53:28.456387+0200 Ate[6956:2981607] Row: 1 , section: 0 2018-04-26
> 15:53:28.457095+0200 Ate[6956:2981607] table view: <ATQueryTableView:
> 0x10482a600; baseClass = UITableView; frame = (0 0; 375 667);
> clipsToBounds = YES; gestureRecognizers = <NSArray: 0x1c044f960>;
> layer = <CALayer: 0x1c00362a0>; contentOffset: {0, 80}; contentSize:
> {375, 747}; adjustedContentInset: {315, 0, 0, 0}> 2018-04-26
> 15:53:28.457191+0200 Ate[6956:2981607] CELL DATA
> UPDATE:<ATTimeLineMealCell: 0x104162a00; baseClass = UITableViewCell;
> frame = (0 80; 375 120); autoresize = W; layer = <CALayer:
> 0x1c4437bc0>>
>
>
> 2018-04-26 15:53:29.814609+0200 Ate[6956:2981607] table view:
> <ATQueryTableView: 0x10482a600; baseClass = UITableView; frame = (0 0;
> 375 667); clipsToBounds = YES; gestureRecognizers = <NSArray:
> 0x1c044f960>; layer = <CALayer: 0x1c00362a0>; contentOffset: {0, 80};
> contentSize: {375, 747}; adjustedContentInset: {315, 0, 0, 0}>
> 2018-04-26 15:53:29.816399+0200 Ate[6956:2981607] CELL DATA:
> <ATTimeLineMealCell: 0x1040aa800; baseClass = UITableViewCell; frame =
> (0 80; 375 120); hidden = YES; autoresize = W; layer = <CALayer:
> 0x1c4437de0>> 2018-04-26 15:53:29.816420+0200 Ate[6956:2981607] Row: 1
> , section: 0 2018-04-26 15:53:29.816792+0200 Ate[6956:2981607] table
> view: <ATQueryTableView: 0x10482a600; baseClass = UITableView; frame =
> (0 0; 375 667); clipsToBounds = YES; gestureRecognizers = <NSArray:
> 0x1c044f960>; layer = <CALayer: 0x1c00362a0>; contentOffset: {0, 80};
> contentSize: {375, 747}; adjustedContentInset: {315, 0, 0, 0}>
> 2018-04-26 15:53:29.816849+0200 Ate[6956:2981607] CELL DATA
> UPDATE:<ATTimeLineMealCell: 0x1040aa800; baseClass = UITableViewCell;
> frame = (0 80; 375 120); autoresize = W; layer = <CALayer:
> 0x1c4437de0>>
Из журнала кажется, что, когда приходит обновление, он создает еще одну ячейку для той же indexPath:
- исходная ячейка адрес памяти: 0x1040aa800
- недавно созданный, но почему? адрес памяти: 0x104162a00
ios uitableview
2 ответа
0 congsun [2018-04-26 17:54:00]
Поэтому, если вы хотите получить точную ячейку обратно, используйте уникальный cellReuseIdentifier только для этой ячейки, и это предотвратит повторное использование ячейки. Однако для UITableView повторное использование ячеек является нормальным, и оно должно быть правильно реализовано, поэтому представление не займет слишком много памяти (потому что ячейка на экране будет повторно использована для нового содержимого). Вы должны заботиться только о том, как очистить ячейку и снова украсить ее новыми данными, а не просто вернуть старую ячейку к той же indexPath.
0 matt [2018-04-26 17:13:00]
cellForRowAtIndexPath
,dequeueReusableCellWithIdentifier
не возвращает ячейку, что мне нужно
Вы не понимаете, как работают таблицы. Ячейки повторно используются. Один и тот же объект ячейки может использоваться теперь в одной строке, теперь в другой строке. Одна и та же строка может быть занята одним объектом ячейки, теперь другим. Нет корреспонденции. Это полностью не зависит от вас, и совершенно не имеет значения, какую ячейку вы используете для определенного указательного пути. Ваша задача - настроить любой объект ячейки, который вы получаете, чтобы он был правильным для этого указательного пути.