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 не возвращает ячейку, что мне нужно

Вы не понимаете, как работают таблицы. Ячейки повторно используются. Один и тот же объект ячейки может использоваться теперь в одной строке, теперь в другой строке. Одна и та же строка может быть занята одним объектом ячейки, теперь другим. Нет корреспонденции. Это полностью не зависит от вас, и совершенно не имеет значения, какую ячейку вы используете для определенного указательного пути. Ваша задача - настроить любой объект ячейки, который вы получаете, чтобы он был правильным для этого указательного пути.