Objective C中数组排序几种情况的总结
总结OC中数组排序3种方法:sortedArrayUsingSelector:;sortedArrayUsingComparator:;sortedArrayUsingDescriptors:
目录[-]
大体上,OC中常用的数组排序有以下几种方法:sortedArrayUsingSelector:;sortedArrayUsingComparator:;sortedArrayUsingDescriptors:
1、简单排序(sortedArrayUsingSelector:)
如果只是对字符串的排序,可以利用sortedArrayUsingSelector:方法就可以了,代码如下
1
2
3
4
5
6
|
//简单排序 void sortArray1(){ NSArray *array = [NSArray arrayWithObjects:@ "abc" ,@ "456" ,@ "123" ,@ "789" ,@ "ef" , nil]; NSArray *sortedArray = [array sortedArrayUsingSelector:@selector(compare:)]; NSLog(@ "排序后:%@" ,sortedArray); } |
当然,除了利用字符串自带的compare:方法,也可以自己写compare:方法,进行对象的比较;如下:
首先是新建了Person类,实现方法如下(头文件就省了):
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
#import "Person.h" @implementation Person //直接实现静态方法,获取带有name和age的Person对象 +(Person *)personWithAge:( int ) age withName:(NSString *)name{ Person *person = [[Person alloc] init]; person.age = age; person.name = name; return person; } //自定义排序方法 -(NSComparisonResult)comparePerson:(Person *)person{ //默认按年龄排序 NSComparisonResult result = [[NSNumber numberWithInt:person.age] compare:[NSNumber numberWithInt:self.age]]; //注意:基本数据类型要进行数据转换 //如果年龄一样,就按照名字排序 if (result == NSOrderedSame) { result = [self.name compare:person.name]; } return result; } @end |
主函数代码如下:
1
2
3
4
5
6
7
8
9
10
|
void sortArray2(){ Person *p1 = [Person personWithAge:23 withName:@ "zhangsan" ]; Person *p2 = [Person personWithAge:21 withName:@ "lisi" ]; Person *p3 = [Person personWithAge:24 withName:@ "wangwu" ]; Person *p4 = [Person personWithAge:24 withName:@ "liwu" ]; Person *p5 = [Person personWithAge:20 withName:@ "liwu" ]; NSArray *array = [NSArray arrayWithObjects:p1,p2,p3,p4,p5, nil]; NSArray *sortedArray = [array sortedArrayUsingSelector:@selector(comparePerson:)]; NSLog(@ "排序后:%@" ,sortedArray); } |
2、利用block语法(sortedArrayUsingComparator:)
苹果官方提供了block语法,比较方便。其中数组排序可以用sortedArrayUsingComparator:方法,代码如下:
1
2
3
4
5
6
7
8
9
10
|
void sortArray3(){ NSArray *array = [NSArray arrayWithObjects:@ "1bc" ,@ "4b6" ,@ "123" ,@ "789" ,@ "3ef" , nil]; NSArray *sortedArray = [array sortedArrayUsingComparator:^NSComparisonResult(id obj1, id obj2) { //这里的代码可以参照上面compare:默认的排序方法,也可以把自定义的方法写在这里,给对象排序 NSComparisonResult result = [obj1 compare:obj2]; return result; }]; NSLog(@ "排序后:%@" ,sortedArray); } |
3、高级排序(sortedArrayUsingDescriptors:)
如果是这样一种情况呢?Person类里有另外一个类的变量,比如说Person类除了name,age变量,还有一辆车Car类型,Car类里有个name属性。对Person对象进行排序,有这样的要求:按照Car的name排序,如果是同一辆车,也就是Car的name相同,那么再按照年龄进行排序,如果年龄也相同,最后按照Person的name进行排序。
上面这样就要使用第三种方法,利用排序描述器,不多说,有兴趣可以看看API介绍。代码如下:
首先写个Car类,实现类Car.m代码如下:
1
2
3
4
5
6
7
8
9
10
|
#import "Car.h" @implementation Car +(Car *)initWithName:(NSString *)name{ Car *car = [Car alloc] init]; car.name = name; return car; } @end |
然后改写Person类,实现类Person.m代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
#import "Person.h" #import "Car.h" @implementation Person +(Person *)personWithAge:( int )age withName:(NSString *)name withCar:(Car *)car{ Person *person = [[Person alloc] init]; person.age = age; person.name = name; person.car = car; return person; } //这里重写description方法,用于最后测试排序结果显示 -(NSString *)description{ return [NSString stringWithFormat:@ "age is %zi , name is %@, car is %@" ,_age,_name,_car.name]; } @end |
主函数代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
void sortArray4(){ //首先来3辆车,分别是奥迪、劳斯莱斯、宝马 Car *car1 = [Car initWithName:@ "Audio" ]; Car *car2 = [Car initWithName:@ "Rolls-Royce" ]; Car *car3 = [Car initWithName:@ "BMW" ]; //再来5个Person,每人送辆车,分别为car2、car1、car1、car3、car2 Person *p1 = [Person personWithAge:23 withName:@ "zhangsan" withCar:car2]; Person *p2 = [Person personWithAge:21 withName:@ "zhangsan" withCar:car1]; Person *p3 = [Person personWithAge:24 withName:@ "lisi" withCar:car1]; Person *p4 = [Person personWithAge:23 withName:@ "wangwu" withCar:car3]; Person *p5 = [Person personWithAge:23 withName:@ "wangwu" withCar:car2]; //加入数组 NSArray *array = [NSArray arrayWithObjects:p1,p2,p3,p4,p5, nil]; //构建排序描述器 NSSortDescriptor *carNameDesc = [NSSortDescriptor sortDescriptorWithKey:@ "car.name" ascending:YES]; NSSortDescriptor *personNameDesc = [NSSortDescriptor sortDescriptorWithKey:@ "name" ascending:YES]; NSSortDescriptor *personAgeDesc = [NSSortDescriptor sortDescriptorWithKey:@ "age" ascending:YES]; //把排序描述器放进数组里,放入的顺序就是你想要排序的顺序 //我这里是:首先按照年龄排序,然后是车的名字,最后是按照人的名字 NSArray *descriptorArray = [NSArray arrayWithObjects:personAgeDesc,carNameDesc,personNameDesc, nil]; NSArray *sortedArray = [array sortedArrayUsingDescriptors: descriptorArray]; NSLog(@ "%@" ,sortedArray); } |
结果如下:
从结果看出,先按照age排序,如果age相同,按照car排序,如果car相同,按照name排序。
(注意:上面两种排序方法要想实现字符串显示,请重写description方法)
Objective C中数组排序几种情况的总结的更多相关文章
- OC中数组排序的3种方法
总结OC中数组排序3种方法:sortedArrayUsingSelector:;sortedArrayUsingComparator:;sortedArrayUsingDescriptors: 大体上 ...
- html/css基础篇——DOM中关于脱离文档流的几种情况分析
所谓的文档流,指的是元素排版布局过程中,元素会自动从左往右,从上往下的流式排列.并最终窗体自上而下分成一行行, 并在每行中按从左至右的顺序排放元素.脱离文档流即是元素打乱了这个排列,或是从排版中拿走. ...
- try catch finally 中包含return的几种情况,及返回结果
当当当,兴致勃勃的第二篇博客,散花~ 下面是正题(敲黑板) 第一种情况:在try和catch中有return,finally中没有return,且finally中没有对try或catch中要 retu ...
- [转]DB2中需要REORG操作的几种情况
问题: 在DB2数据库中,修改完表的结构时,是否需要对表做一个reorg操作才能使表的状态恢复正常? 答:有以下4种操作,需要对表做reorg操作 1. SET DATA TYPE altered-d ...
- C++中内存泄漏的几种情况
1. 在类的构造函数和析构函数中没有匹配的调用new和delete函数 两种情况下会出现这种内存泄露:一是在堆里创建了对象占用了内存,但是没有显示地释放对象占用的内存:二是在类的构造函数中动态的分配了 ...
- Java中关于变量的几种情况
Java中关于变量的几种情况 1.继承时变量的引用关系 class Animals { int age = 10; void enjoy() { System.out.println("An ...
- 从零开始学习前端JAVASCRIPT — JavaScript中this指向的四种情况
JavaScript中this的四种情况(非严格模式) 1.当this所在函数是事件处理函数时,this指向事件源.2.当this所在函数是构造函数时,this指向new出来的对象.3.this所在函 ...
- 几种TCP连接中出现RST的情况(转载)
TCP RST 网络 linux 目录[-] 1 端口未打开 2 请求超时 3 提前关闭 4 在一个已关闭的socket上收到数据 总结 参考文献: 应该没有人会质疑,现在是一个网络时代了.应该不少程 ...
- c++中vector向量几种情况的总结(向量指针,指针的向量)
1.标准库vector类型 vector 是同一种类型的对象的集合.每一个对象都有一个相应的整数索引值.标准库将负责管理与存储元素相关的内存.我们把 vector 称为容器,是由于它能够包括其它对象. ...
随机推荐
- Python之路 day2 字符串/元组/列表/字典互转
#-*-coding:utf-8-*- #1.字典 dict = {'name': 'Zara', 'age': 7, 'class': 'First'} #字典转为字符串,返回:<type ' ...
- 揭开Socket编程的面纱
对TCP/IP.UDP.Socket编程这些词你不会很陌生吧?随着网络技术的发展,这些词充斥着我们的耳朵.那么我想问: 1. 什么是TCP/IP.UDP? 2. Socket在哪里呢? 3. Sock ...
- css学习笔记 10
一个竖向导航,假设ul宽度为100px,li不浮动,在各浏览器下都会正常显示,当li左浮动时,在标准浏览器下,li会横向排列,如果第一行的剩余空间的宽度不够下一个li,下一个li自动换到第二行,第二行 ...
- MySQL update时使用联表,聚合
原文地址 http://stackoverflow.com/questions/3022405/mysql-update-query-with-left-join-and-group-by UPDAT ...
- Linux下漏洞提权
Linux下的漏洞提权 linux下一般都是系统漏洞提权,分为以下几个步骤:
- VC界面最前端显示
//显示在最前端 m_pMainWnd->SetWindowPos(&CWnd::wndTopMost, 0,0,0,0,SWP_NOMOVE|SWP_NOSIZE); if (m_pM ...
- 环境jdk、编码不一致造成的项目报错
一个项目在eclipse 中可以运行 , 到另一个eclipse 中不能运行,多是因为jdk过低.包没有引人.环境jdk.编码不一致造成的.或者是因为编译文件在另一个环境里跟JDK等 不匹配. 解决办 ...
- [原创]C#应用WindowsApi实现查找\枚举(FindWindow、EnumChildWindows)窗体控件,并发送消息。
首先介绍基本WindowsApi: public static extern IntPtr FindWindow(string lpClassName, string lpWindowName); 函 ...
- Linux x64 下 Matlab R2013a 300 kb 脚本文件调试的 CPU 占用过高问题的解决办法
(1) 系统+软件版本 CentOS 6.5 (Final), 64 位,内核initramfs-2.6.32-431.5.1.el6.x86_64, MATLAB Version: 8.1.0.60 ...
- dom事件与event对象总结
1 事件:就是文档或浏览器窗口中发生的一些特定的交互瞬间. tips:js和xhtml的交互是通过当用户或浏览器操作网页时发生的事件来处理的. 1.1 事件流:即事件的顺序. 事件 ...