Objective C中数组排序几种情况的总结(转自long458)

总结OC中数组排序3种方法:sortedArrayUsingSelector:;sortedArrayUsingComparator:;sortedArrayUsingDescriptors:

数组排序 Objective-C

目录[-]

大体上,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方法)

时间: 2024-11-05 14:45:47

Objective C中数组排序几种情况的总结(转自long458)的相关文章

Objective C中数组排序几种情况的总结

总结OC中数组排序3种方法:sortedArrayUsingSelector:;sortedArrayUsingComparator:;sortedArrayUsingDescriptors: 数组排序 Objective-C 目录[-] 1.简单排序(sortedArrayUsingSelector:) 2.利用block语法(sortedArrayUsingComparator:) 3.高级排序(sortedArrayUsingDescriptors:) 大体上,OC中常用的数组排序有以下几

DOM中关于脱离文档流的几种情况分析

所谓的文档流,指的是元素排版布局过程中,元素会自动从左往右,从上往下的流式排列.并最终窗体自上而下分成一行行, 并在每行中按从左至右的顺序排放元素.脱离文档流即是元素打乱了这个排列,或是从排版中拿走. 当前所知的脱离文档流的方式有两种:浮动和定位. a.定位属性positon 先看一下定位.看一段对定位各个字段的描述,有助于理解 值 描述 absolute 生成绝对定位的元素,相对于 static 定位以外的第一个父元素进行定位. 元素的位置通过 "left", "top&q

链表中插入一个节点的三种情况

在链表中插入一个元素可以分为三种情况: 1.在节点的时候 2.在链表中间的任意位置 3.在链表的最后位置,也可以认为这种情况为追加(这个就留到追加的时候来实现) 下面是代码的实现 SN *Insert_S_Node( SN *head ) /* 传入的参数是被插入链表中的头指针 */ { SN *Insert_Node=NULL, *Dest_Node = NULL; /* Insert_Node是将要做成的新链表中的节点 Dest_Node是要插入的节点*/ INT32 OSM = 1, i3

java中内部类的创建四种情况,三种方式,及内部数据访问权限

内部类和外部类的关系,及内部静态类的数据访问权限,声明方式. 第一种,在外部类内部声明使用内部类,内部类的类型为static和非 static类型,内部类数据类型为private,protected,public 类型的访问权限.外部类为非静态声明和权限如下: package com; public class Test1 { //@author 张春蕾 private class Name{ private int i =1; public int s = 2; protected int m

[转]DB2中需要REORG操作的几种情况

问题: 在DB2数据库中,修改完表的结构时,是否需要对表做一个reorg操作才能使表的状态恢复正常? 答:有以下4种操作,需要对表做reorg操作 1. SET DATA TYPE altered-data-type  但有以下两种情况是例外,不需要reorg:          1). Increasing the length of a VARCHAR or VARGRAPHIC column          2). Decreasing the length of a VARCHAR o

Struts2+Urlrewrite实现伪静态化 demo中介绍了三种情况的配置,下载即可运行。

原文:Struts2+Urlrewrite实现伪静态化 demo中介绍了三种情况的配置,下载即可运行. 源代码下载地址:http://www.zuidaima.com/share/1550463499504640.htm 为大家提供了3种模式的url进行访问,以便应付大家的开发,更多的模式大家可以自行组合. html:http://localhost:8686/Sturts2UrlReWrite/line.html xxx::http://localhost:8686/Sturts2UrlReW

C++中必须用参数列表初始化的4种情况

在C++中,必须使用构造函的参数列表来初始化成员变量的4种情况如下:(1)成员变量类型为 const int m_nData; class  test { private:    const int m_nData; public:    test():m_nData(120){} }; (2)类中有引用型变量  class  test  {   private:            int m_nData;      const int & m_nTest;   public:      t

几种TCP连接中出现RST的情况(转载)

TCP RST 网络 linux 目录[-] 1 端口未打开 2 请求超时 3 提前关闭 4 在一个已关闭的socket上收到数据 总结 参考文献: 应该没有人会质疑,现在是一个网络时代了.应该不少程序员在编程中需要考虑多机.局域网.广域网的各种问题.所以网络知识也是避免不了学习的.而且笔者一直觉得TCP/IP网络知识在一个程序员知识体系中必需占有一席之地的. 在TCP协议中RST表示复位,用来异常的关闭连接,在TCP的设计中它是不可或缺的.发送RST包关闭连接时,不必等缓冲区的包都发出去,直接

java中基本类型与装箱基本类型“==”比较出现的几种情况

java中基本类型与装箱基本类型"=="比较出现的几种情况 java有一个类型系统有两部分组成,包含基本类型(primitive),例如:int.double等,还有引用类型(reference type),例如:String.List.每个基本类型都有一个对应的引用类型,称为装箱基本类型(boxed promitive).装箱基本类型中对应于int.double的是Integer.Double. Java 1.5发行版本中增加了自动装箱和自动拆箱,自动装箱和自动拆箱就是我们所知道的&