// Person.h #import <Foundation/Foundation.h> @interface Person : NSObject @property (nonatomic, assign) int age; @end
// Person.m #import "Person.h" @implementation Person - (NSString *)description { return [NSString stringWithFormat:@"age = %i", _age]; } @end
// // main.m // NSArray排序 #import <Foundation/Foundation.h> #import "Person.h" int main(int argc, const char * argv[]) { NSArray *arr1 = @[@10, @20, @5, @7, @15]; //oc中的数字,@5是oc的对象, NSLog(@"排序前: %@", arr1);//(10,20,5,7,15) // 注意: 想使用compare方法对数组中的元素进行排序, 那么数组中的元素必须是Foundation框架中的对象(oc对象), 也就是说不能是自定义对象 NSArray *newArr1 = [arr1 sortedArrayUsingSelector:@selector(compare:)]; //NSArray是不可变的,所以要用新的数组接收。 NSLog(@"排序后: %@", newArr1);//(5,7,10,15,20) Person *p1 = [Person new]; p1.age = 10; Person *p2 = [Person new]; p2.age = 20; Person *p3 = [Person new]; p3.age = 5; Person *p4 = [Person new]; p4.age = 7; NSArray *arr = @[p1, p2, p3, p4]; NSLog(@"排序前: %@", arr);//("age = 10","age = 20","age = 5","age = 7") // 按照人的年龄进行排序 // 不能使用compare:方法对自定义对象进行排序 //NSArray *newArr11 = [arr sortedArrayUsingSelector:@selector(compare:)]; // 该方法默认会按照升序排序,NSSortStable表示是安全的,涉及多线程, NSArray *newArr = [arr sortedArrayWithOptions:NSSortStable usingComparator:^NSComparisonResult(Person *obj1, Person *obj2) { // 每次调用该block都会取出数组中的两个元素给我们,二分算法, NSLog(@"obj1 = %@, obj2 = %@", obj1, obj2); //排序算法 return obj1.age > obj2.age; // return obj1.age < obj2.age; /* if (obj1.age > obj2.age) { // 5 4 return NSOrderedDescending; }else if(obj1.age < obj2.age) { // 4 5 return NSOrderedAscending; }else { return NSOrderedSame; } */ }]; NSLog(@"排序后: %@", newArr);// ("age = 5","age = 7","age = 10","age = 20") return 0; }
本文转自农夫山泉别墅博客园博客,原文链接:http://www.cnblogs.com/yaowen/p/7440624.html,如需转载请自行联系原作者