Что такое аргумент BOOL * stop для enumerateObjectsUsingBlock: используется для?

В последнее время я использую enumerateObjectsUsingBlock: для моих быстрых запросов, и мне трудно понять использование BOOL *stop в блоке перечисления.

В ссылочных состояниях класса NSArray

stop: ссылка на логическое значение. Блок может установить значение YES в прекратите дальнейшую обработку массива. Аргумент stop - это исключение аргумент. Вы должны установить этот булев только YES в пределах Блок.

Итак, конечно, я могу добавить в свой блок следующее, чтобы остановить перечисление:

if (idx == [myArray indexOfObject:[myArray lastObject]]) {
    *stop = YES;
}

Из того, что я смог рассказать, явным образом установка *stop в YES не имеет отрицательных побочных эффектов. Кажется, что перечисление автоматически останавливается в конце массива. Так использует *stop действительно необходимый в блоке?

Ответ 1

Аргумент stop для блока позволяет вам преждевременно остановить перечисление. Это эквивалентно break из нормального цикла for. Вы можете игнорировать его, если хотите пройти через каждый объект в массиве.

for( id obj in arr ){
    if( [obj isContagious] ){
        break;    // Stop enumerating
    }

    if( ![obj isKindOfClass:[Perefrigia class]] ){
        continue;    // Skip this object
    }

    [obj immanetizeTheEschaton];
}

[arr enumerateObjectsUsingBlock:^(id obj, NSUInteger idx, BOOL *stop) {
    if( [obj isContagious] ){
        *stop = YES;    // Stop enumerating
        return;
    }

    if( ![obj isKindOfClass:[Perefrigia class]] ){
        return;    // Skip this object
    }

    [obj immanentizeTheEschaton];
}];

Это параметр out, потому что это ссылка на переменную из области вызова. Он должен быть установлен внутри вашего блока, но читать внутри enumerateObjectsUsingBlock:, так же, как и NSError, обычно передаются обратно в ваш код из вызовов инфраструктуры.

- (void)enumerateObjectsUsingBlock:(void (^)(id obj, NSUInteger idx, BOOL *stop))block {
    // N.B: This is probably not how this method is actually implemented!
    // It is just to demonstrate how the out parameter operates!

    NSUInteger idx = 0;
    for( id obj in self ){

        BOOL stop = NO;

        block(obj, idx++, &stop);

        if( stop ){
            break;
        }
    }
}