Dai uno sguardo allo keypaths. Sono super potenti e li uso al posto delle classi NSPredicate per la maggior parte del tempo. Ecco come li usa nel tuo esempio ...
NSArray *uniqueStates;
uniqueStates = [customObjects valueForKeyPath:@"@distinctUnionOfObjects.state"];
Nota l'uso di valueForKeyPath invece di valueForKey.
Ecco un esempio più dettagliato/artificioso ...
NSDictionary *arnold = [NSDictionary dictionaryWithObjectsAndKeys:@"arnold", @"name", @"california", @"state", nil];
NSDictionary *jimmy = [NSDictionary dictionaryWithObjectsAndKeys:@"jimmy", @"name", @"new york", @"state", nil];
NSDictionary *henry = [NSDictionary dictionaryWithObjectsAndKeys:@"henry", @"name", @"michigan", @"state", nil];
NSDictionary *woz = [NSDictionary dictionaryWithObjectsAndKeys:@"woz", @"name", @"california", @"state", nil];
NSArray *people = [NSArray arrayWithObjects:arnold, jimmy, henry, woz, nil];
NSLog(@"Unique States:\n %@", [people valueForKeyPath:@"@distinctUnionOfObjects.state"]);
// OUTPUT
// Unique States:
// "california",
// "michigan",
// "new york"
Mentre mi piace anche il potere di @distinctUnionOfObjects, e, di conseguenza, l'utente risposta probablyCorey ha dato, il vantaggio di questo approccio sintetico qui in questa soluzione è che l'ordinamento è preservato. – idStar