Question

Is this a bug?

I have this lines:

[myArray enumerateObjectsUsingBlock:^(id obj, NSUInteger idx, BOOL *stop) {

     NSLog(@"%d", idx);
}];

NSLog(@"end");

This should print like this

"0"
"1"
"2"
...
"end"

but it is printing like

"end"
"0"
"1"
"2"
...

Apple says enumerateObjectsWithOptions:usingBlock: is synchronous, so "end" should not be printed before the enumeration, right?

Can you guys confirm?

Was it helpful?

Solution

enumerateObjectsUsingBlock: is definitely synchronous. I just ran the same example in CodeRunner:

NSArray *myArray = @[ @1, @2, @3, @4, @5 ];
[myArray enumerateObjectsUsingBlock:^(id obj, NSUInteger idx, BOOL *stop) {
    NSLog(@"%d", idx);
}];

NSLog(@"end");

And got the following output:

0
1
2
3 
4
end

OTHER TIPS

Cannot confirm this, it's printing as expected: "0","1","2","End". Also notice that you are printing indexes but your log starts at "1".

Licensed under: CC-BY-SA with attribution
Not affiliated with StackOverflow
scroll top