NSArray的排序方法
转自:http://blog.csdn.net/lixuwen521/article/details/7848893
1.sortedArrayUsingSelector
- NSMutableArray *array = [NSMutableArray arrayWithObjects:
- [NSDictionary dictionaryWithObjectsAndKeys:@"Obj0", [NSNumber numberWithInt:0], nil],
- [NSDictionary dictionaryWithObjectsAndKeys:@"Obj5", [NSNumber numberWithInt:5], nil],
- [NSDictionary dictionaryWithObjectsAndKeys:@"Obj2", [NSNumber numberWithInt:2], nil],
- [NSDictionary dictionaryWithObjectsAndKeys:@"Obj3", [NSNumber numberWithInt:3], nil],
- [NSDictionary dictionaryWithObjectsAndKeys:@"Obj1", [NSNumber numberWithInt:1], nil],
- [NSDictionary dictionaryWithObjectsAndKeys:@"Obj4", [NSNumber numberWithInt:4], nil], nil];
- NSArray *resultArray = [array sortedArrayUsingSelector:@selector(compare:)];
- .h
- @interface NSDictionary (compare)
- {}
- -(NSComparisonResult)compare:(NSDictionary *)otherDictionary;
- @end
- .m
- @implementation NSDictionary (compare)
- - (NSComparisonResult)compare: (NSDictionary *)otherDictionary
- {
- NSDictionary *tempDictionary = (NSDictionary *)self;
- NSNumber *number1 = [[tempDictionary allKeys] objectAtIndex:0];
- NSNumber *number2 = [[otherDictionary allKeys] objectAtIndex:0];
- NSComparisonResult result = [number1 compare:number2];
- return result == NSOrderedDescending; // 升序
- // return result == NSOrderedAscending; // 降序
- }
- @end
2.sortedArrayUsingComparator
- NSMutableArray *array = [NSMutableArray arrayWithObjects:
- [NSDictionary dictionaryWithObjectsAndKeys:@"Obj0", [NSNumber numberWithInt:0], nil],
- [NSDictionary dictionaryWithObjectsAndKeys:@"Obj5", [NSNumber numberWithInt:5], nil],
- [NSDictionary dictionaryWithObjectsAndKeys:@"Obj2", [NSNumber numberWithInt:2], nil],
- [NSDictionary dictionaryWithObjectsAndKeys:@"Obj3", [NSNumber numberWithInt:3], nil],
- [NSDictionary dictionaryWithObjectsAndKeys:@"Obj1", [NSNumber numberWithInt:1], nil],
- [NSDictionary dictionaryWithObjectsAndKeys:@"Obj4", [NSNumber numberWithInt:4], nil], nil];
- NSArray *resultArray = [array sortedArrayUsingSelector:@selector(compare:)];
- NSArray *resultArray = [array sortedArrayUsingComparator:^NSComparisonResult(id obj1, id obj2) {
- NSNumber *number1 = [[obj1 allKeys] objectAtIndex:0];
- NSNumber *number2 = [[obj2 allKeys] objectAtIndex:0];
- NSComparisonResult result = [number1 compare:number2];
- return result == NSOrderedDescending; // 升序
- return result == NSOrderedAscending; // 降序
- }];
3.sortedArrayUsingDescriptors & sortUsingDescriptors
- .h
- @interface Person : NSObject
- {
- NSString *_name;
- NSInteger _age;
- }
- @property (nonatomic, retain) NSString *name;
- @property (nonatomic, assign) NSInteger age;
- @end
- .m
- @implementation Person
- @synthesize name = _name;
- @synthesize age = _age;
- - (void)dealloc
- {
- [_name release];
- [super dealloc];
- }
- @end
- Person *person1 = [[Person alloc] init];
- [person1 setName:@"ABC"];
- [person1 setAge:24];
- Person *person2 = [[Person alloc] init];
- [person2 setName:@"ACB"];
- [person2 setAge:22];
- Person *person3 = [[Person alloc] init];
- [person3 setName:@"ABD"];
- [person3 setAge:33];
- NSMutableArray *array = [NSMutableArray arrayWithObjects:person1, person2, person3, nil];
- [person1 release];
- [person2 release];
- [person3 release];
- NSSortDescriptor *sortDescriptor = [NSSortDescriptor sortDescriptorWithKey:@"_age" ascending:YES];
- NSArray *tempArray = [array sortedArrayUsingDescriptors:[NSArray arrayWithObject:sortDescriptor]];
- for(NSInteger i = 0; i < [tempArray count]; i++)
- {
- NSLog(@"%@--------%d\n", [[tempArray objectAtIndex:i] name], [[tempArray objectAtIndex:i] age]);
- }
- // [array sortUsingDescriptors:[NSArray arrayWithObject:sortDescriptor]];
- //
- // for(NSInteger i = 0; i < [array count]; i++)
- // {
- // NSLog(@"%@--------%d\n", [[array objectAtIndex:i] name], [[array objectAtIndex:i] age]);
- // }
sortDescriptorWithKey:@"_age",以age作为标准来做比较。
- Person *person1 = [[Person alloc] init];
- [person1 setName:@"ABCD"];
- [person1 setAge:24];
- Person *person2 = [[Person alloc] init];
- [person2 setName:@"ACBD"];
- [person2 setAge:22];
- Person *person3 = [[Person alloc] init];
- [person3 setName:@"ABDC"];
- [person3 setAge:33];
- Person *person4 = [[Person alloc] init];
- [person4 setName:@"ACDB"];
- [person4 setAge:22];
- NSMutableArray *array = [NSMutableArray arrayWithObjects:person1, person3, person4, person2, nil];
- [person1 release];
- [person2 release];
- [person3 release];
- [person4 release];
- NSSortDescriptor *sortDescriptor1 = [NSSortDescriptor sortDescriptorWithKey:@"_age" ascending:YES];
- NSSortDescriptor *sortDescriptor2 = [NSSortDescriptor sortDescriptorWithKey:@"_name" ascending:YES];
- NSArray *tempArray = [array sortedArrayUsingDescriptors:[NSArray arrayWithObjects:sortDescriptor1, sortDescriptor2, nil]];
- for(NSInteger i = 0; i < [tempArray count]; i++)
- {
- NSLog(@"%@--------%d\n", [[tempArray objectAtIndex:i] name], [[tempArray objectAtIndex:i] age]);
- }
- // [array sortUsingDescriptors:[NSArray arrayWithObject:sortDescriptor]];
- //
- // for(NSInteger i = 0; i < [array count]; i++)
- // {
- // NSLog(@"%@--------%d\n", [[array objectAtIndex:i] name], [[array objectAtIndex:i] age]);
- // }
NSSortDescriptor *sortDescriptor1 = [NSSortDescriptorsortDescriptorWithKey:@"_age"ascending:YES];
NSSortDescriptor *sortDescriptor2 = [NSSortDescriptorsortDescriptorWithKey:@"_name"ascending:YES];
NSArray *tempArray = [array sortedArrayUsingDescriptors:[NSArrayarrayWithObjects:sortDescriptor1, sortDescriptor2, nil]];
这里的NSArray中的第一元素表示首先按照这个元素的升序或者降序进行排序,对于有重复项的,再按照第二元素进行排序,依次进行类推
NSArray的排序方法的更多相关文章
- NSArray排序方法讲解
NSArray排序方法讲解 给数组排序有着多种方式 最麻烦的是sortedArrayUsingSelector:,其次是sortedArrayUsingDescriptors:,最容易使用的就是sor ...
- 深入理解苹果系统(Unicode)字符串的排序方法
欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 本文由iminder发表于云+社区专栏 Unicode编码 我们知道计算机是不能直接处理文本的,而是和数字打交道.因此,为了表示文本,就建立 ...
- JavaScript高级程序设计--对象,数组(栈方法,队列方法,重排序方法,迭代方法)
1.使用对象字面量定义对象 var person={}; 使用这种方式创建对象时,实际上不会调用Object构造函数. 开发人员更喜欢对象字面量的语法. 2.有时候需要传递大量可选参数的情形时,一 ...
- php语言实现的7种基本的排序方法
今天总结了一下常用的7种排序方法,并用php语言实现. 直接插入排序 /* * 直接插入排序,插入排序的思想是:当前插入位置之前的元素有序, * 若插入当前位置的元素比有序元素最后一个元素大,则什么也 ...
- C语言中常见的排序方法
在C语言中,常见的排序方法有冒泡法,排序法,插入法等等.所谓的冒泡法,就是对一组数字进行从大到小或者从小到大的一种排序方法.主要就是相邻的数值相互交换.从第一个数值开始,如果这相邻的两个数值排序与我们 ...
- Atitit.现实生活中最好使用的排序方法-----ati排序法总结
Atitit.现实生活中最好使用的排序方法-----ati排序法总结 1. 现在的问题 1 2. 排序的类别::插入排序//交换排序//选择排序(每次最小/大排在相应的位置 )//归并排序//基数排 ...
- 转:Java实现几种常见排序方法
日常操作中常见的排序方法有:冒泡排序.快速排序.选择排序.插入排序.希尔排序,甚至还有基数排序.鸡尾酒排序.桶排序.鸽巢排序.归并排序等. 冒泡排序是一种简单的排序算法.它重复地走访过要排序的数列,一 ...
- java提供的默认list排序方法-转
1.java提供的默认list排序方法 主要代码: List<String> list = new ArrayList();list.add("刘媛媛"); list. ...
- Flex Array内置排序方法的使用
在Array类中,提供内置的排序方法.排序是在软件开发的过程中,经常遇到的问题.通过这些内置的方法,可以快速轻便的进行排序操作. Array类提供sort方法对Array实例进行排序.sort方法没有 ...
随机推荐
- PHP MySQL -处理语句
PHP MySQL 预处理语句 预处理语句对于防止 MySQL 注入是非常有用的. 预处理语句及绑定参数 预处理语句用于执行多个相同的 SQL 语句,并且执行效率更高. 预处理语句的工作原理如下: 预 ...
- HTML二(基本标签)
一.标题 HTML 标题(Heading)是通过 <h1> - <h6> 等标签进行定义的. <!--标题--> <h1>标题 1</h1> ...
- #define中的“#”和“##”的作用
在#define中,标准只定义了#和##两种操作: #用来把参数转换成字符串: ##则用来连接两个前后两个参数,把它们变成一个字符串.
- Asp.Net MVC:return View()、return View("Login")、return Login()、return RedirectToAction("Login") 的区别
在做登录页面的时候发现的一些情况: ------------------------------------------------------------------------- public A ...
- Android 逆向project 实践篇
Android逆向project 实践篇 上篇给大家介绍的是基础+小Demo实践. 假设没有看过的同学能够进去看看.(逆向project 初篇) 本篇主要给大家介绍怎样反编译后改动源代码, 并打包执行 ...
- MySQL工具1:mysqladmin
每两秒显示一下MySQL的状态,一共显示5次. # mysqladmin -uroot -p -i 2 -c 5 status 查看MySQL的运行状态: #mysqladmin -uroot -p ...
- Linux高级权限管理
传统的UGO(rwx-wx-wx)权限模型,无法解决当多个组需要对一个文件执行某些权限的问题. ACL :访问控制列表access control list一种高级的权限机制,允许我们对文件或者文件夹 ...
- 安装ESXI 5.5卡在LSI_MR3.V00解决方案
安装ESXI 5.5卡在LSI_MR3.V00解决方案 方法一 故障现象 此问题无论使用VMware官方镜像还是HP的自定义镜像都会出现一下情况并卡着不动.(此文档普遍存在各种服务器上,包括其它厂商服 ...
- linux RAID10测试
mdadm命令用于管理系统软件RAID硬盘阵列,格式为:"mdadm [模式] <RAID设备名称> [选项] [成员设备名称]". mdadm命令能够在Linux系统 ...
- Linux下动态共享库加载时的搜索路径详解
对动态库的实际应用还不太熟悉的读者可能曾经遇到过类似“error while loading shared libraries”这样的错误,这是典型的因为需要的动态库不在动态链接器ld.so的搜索路径 ...