转自:http://blog.csdn.net/lixuwen521/article/details/7848893

1.sortedArrayUsingSelector

(按Key值大小对NSDictionary排序)
  1. NSMutableArray *array = [NSMutableArray arrayWithObjects:
  2. [NSDictionary dictionaryWithObjectsAndKeys:@"Obj0", [NSNumber numberWithInt:0], nil],
  3. [NSDictionary dictionaryWithObjectsAndKeys:@"Obj5", [NSNumber numberWithInt:5], nil],
  4. [NSDictionary dictionaryWithObjectsAndKeys:@"Obj2", [NSNumber numberWithInt:2], nil],
  5. [NSDictionary dictionaryWithObjectsAndKeys:@"Obj3", [NSNumber numberWithInt:3], nil],
  6. [NSDictionary dictionaryWithObjectsAndKeys:@"Obj1", [NSNumber numberWithInt:1], nil],
  7. [NSDictionary dictionaryWithObjectsAndKeys:@"Obj4", [NSNumber numberWithInt:4], nil], nil];
  8. NSArray *resultArray = [array sortedArrayUsingSelector:@selector(compare:)];
因为NSDictionary没有compare的排序比较方法,所以需要我们自己写
  1. .h
  2. @interface NSDictionary (compare)
  3. {}
  4. -(NSComparisonResult)compare:(NSDictionary *)otherDictionary;
  5. @end
  6. .m
  7. @implementation NSDictionary (compare)
  8. - (NSComparisonResult)compare: (NSDictionary *)otherDictionary
  9. {
  10. NSDictionary *tempDictionary = (NSDictionary *)self;
  11. NSNumber *number1 = [[tempDictionary allKeys] objectAtIndex:0];
  12. NSNumber *number2 = [[otherDictionary allKeys] objectAtIndex:0];
  13. NSComparisonResult result = [number1 compare:number2];
  14. return result == NSOrderedDescending; // 升序
  15. //    return result == NSOrderedAscending;  // 降序
  16. }
  17. @end

2.sortedArrayUsingComparator

  1. NSMutableArray *array = [NSMutableArray arrayWithObjects:
  2. [NSDictionary dictionaryWithObjectsAndKeys:@"Obj0", [NSNumber numberWithInt:0], nil],
  3. [NSDictionary dictionaryWithObjectsAndKeys:@"Obj5", [NSNumber numberWithInt:5], nil],
  4. [NSDictionary dictionaryWithObjectsAndKeys:@"Obj2", [NSNumber numberWithInt:2], nil],
  5. [NSDictionary dictionaryWithObjectsAndKeys:@"Obj3", [NSNumber numberWithInt:3], nil],
  6. [NSDictionary dictionaryWithObjectsAndKeys:@"Obj1", [NSNumber numberWithInt:1], nil],
  7. [NSDictionary dictionaryWithObjectsAndKeys:@"Obj4", [NSNumber numberWithInt:4], nil], nil];
  8. NSArray *resultArray = [array sortedArrayUsingSelector:@selector(compare:)];
  9. NSArray *resultArray = [array sortedArrayUsingComparator:^NSComparisonResult(id obj1, id obj2) {
  10. NSNumber *number1 = [[obj1 allKeys] objectAtIndex:0];
  11. NSNumber *number2 = [[obj2 allKeys] objectAtIndex:0];
  12. NSComparisonResult result = [number1 compare:number2];
  13. return result == NSOrderedDescending; // 升序
  14. return result == NSOrderedAscending;  // 降序
  15. }];

3.sortedArrayUsingDescriptors & sortUsingDescriptors

前者带返回值,是NSArray的方法,排好序的数组是返回值中的数组;
后者不带返回值,是NSMutableArray的方法,是对当前数组自己排序
  1. .h
  2. @interface Person : NSObject
  3. {
  4. NSString  *_name;
  5. NSInteger  _age;
  6. }
  7. @property (nonatomic, retain) NSString  *name;
  8. @property (nonatomic, assign) NSInteger  age;
  9. @end
  10. .m
  11. @implementation Person
  12. @synthesize name = _name;
  13. @synthesize age  = _age;
  14. - (void)dealloc
  15. {
  16. [_name release];
  17. [super dealloc];
  18. }
  19. @end
  1. Person *person1 = [[Person alloc] init];
  2. [person1 setName:@"ABC"];
  3. [person1 setAge:24];
  4. Person *person2 = [[Person alloc] init];
  5. [person2 setName:@"ACB"];
  6. [person2 setAge:22];
  7. Person *person3 = [[Person alloc] init];
  8. [person3 setName:@"ABD"];
  9. [person3 setAge:33];
  10. NSMutableArray *array = [NSMutableArray arrayWithObjects:person1, person2, person3, nil];
  11. [person1 release];
  12. [person2 release];
  13. [person3 release];
  14. NSSortDescriptor *sortDescriptor = [NSSortDescriptor sortDescriptorWithKey:@"_age" ascending:YES];
  15. NSArray *tempArray = [array sortedArrayUsingDescriptors:[NSArray arrayWithObject:sortDescriptor]];
  16. for(NSInteger i = 0; i < [tempArray count]; i++)
  17. {
  18. NSLog(@"%@--------%d\n", [[tempArray objectAtIndex:i] name], [[tempArray objectAtIndex:i] age]);
  19. }
  20. //    [array sortUsingDescriptors:[NSArray arrayWithObject:sortDescriptor]];
  21. //
  22. //    for(NSInteger i = 0; i < [array count]; i++)
  23. //    {
  24. //        NSLog(@"%@--------%d\n", [[array objectAtIndex:i] name], [[array objectAtIndex:i] age]);
  25. //    }

sortDescriptorWithKey:@"_age",以age作为标准来做比较。

  1. Person *person1 = [[Person alloc] init];
  2. [person1 setName:@"ABCD"];
  3. [person1 setAge:24];
  4. Person *person2 = [[Person alloc] init];
  5. [person2 setName:@"ACBD"];
  6. [person2 setAge:22];
  7. Person *person3 = [[Person alloc] init];
  8. [person3 setName:@"ABDC"];
  9. [person3 setAge:33];
  10. Person *person4 = [[Person alloc] init];
  11. [person4 setName:@"ACDB"];
  12. [person4 setAge:22];
  13. NSMutableArray *array = [NSMutableArray arrayWithObjects:person1, person3, person4, person2, nil];
  14. [person1 release];
  15. [person2 release];
  16. [person3 release];
  17. [person4 release];
  18. NSSortDescriptor *sortDescriptor1 = [NSSortDescriptor sortDescriptorWithKey:@"_age" ascending:YES];
  19. NSSortDescriptor *sortDescriptor2 = [NSSortDescriptor sortDescriptorWithKey:@"_name" ascending:YES];
  20. NSArray *tempArray = [array sortedArrayUsingDescriptors:[NSArray arrayWithObjects:sortDescriptor1, sortDescriptor2, nil]];
  21. for(NSInteger i = 0; i < [tempArray count]; i++)
  22. {
  23. NSLog(@"%@--------%d\n", [[tempArray objectAtIndex:i] name], [[tempArray objectAtIndex:i] age]);
  24. }
  25. //    [array sortUsingDescriptors:[NSArray arrayWithObject:sortDescriptor]];
  26. //
  27. //    for(NSInteger i = 0; i < [array count]; i++)
  28. //    {
  29. //        NSLog(@"%@--------%d\n", [[array objectAtIndex:i] name], [[array objectAtIndex:i] age]);
  30. //    }

NSSortDescriptor *sortDescriptor1 = [NSSortDescriptorsortDescriptorWithKey:@"_age"ascending:YES];

NSSortDescriptor *sortDescriptor2 = [NSSortDescriptorsortDescriptorWithKey:@"_name"ascending:YES];

NSArray *tempArray = [array sortedArrayUsingDescriptors:[NSArrayarrayWithObjects:sortDescriptor1, sortDescriptor2, nil]];

这里的NSArray中的第一元素表示首先按照这个元素的升序或者降序进行排序,对于有重复项的,再按照第二元素进行排序,依次进行类推

NSArray的排序方法的更多相关文章

  1. NSArray排序方法讲解

    NSArray排序方法讲解 给数组排序有着多种方式 最麻烦的是sortedArrayUsingSelector:,其次是sortedArrayUsingDescriptors:,最容易使用的就是sor ...

  2. 深入理解苹果系统(Unicode)字符串的排序方法

    欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 本文由iminder发表于云+社区专栏 Unicode编码 我们知道计算机是不能直接处理文本的,而是和数字打交道.因此,为了表示文本,就建立 ...

  3. JavaScript高级程序设计--对象,数组(栈方法,队列方法,重排序方法,迭代方法)

    1.使用对象字面量定义对象 var person={}; 使用这种方式创建对象时,实际上不会调用Object构造函数. 开发人员更喜欢对象字面量的语法.   2.有时候需要传递大量可选参数的情形时,一 ...

  4. php语言实现的7种基本的排序方法

    今天总结了一下常用的7种排序方法,并用php语言实现. 直接插入排序 /* * 直接插入排序,插入排序的思想是:当前插入位置之前的元素有序, * 若插入当前位置的元素比有序元素最后一个元素大,则什么也 ...

  5. C语言中常见的排序方法

    在C语言中,常见的排序方法有冒泡法,排序法,插入法等等.所谓的冒泡法,就是对一组数字进行从大到小或者从小到大的一种排序方法.主要就是相邻的数值相互交换.从第一个数值开始,如果这相邻的两个数值排序与我们 ...

  6. Atitit.现实生活中最好使用的排序方法-----ati排序法总结

    Atitit.现实生活中最好使用的排序方法-----ati排序法总结 1. 现在的问题 1 2. 排序的类别::插入排序//交换排序//选择排序(每次最小/大排在相应的位置  )//归并排序//基数排 ...

  7. 转:Java实现几种常见排序方法

    日常操作中常见的排序方法有:冒泡排序.快速排序.选择排序.插入排序.希尔排序,甚至还有基数排序.鸡尾酒排序.桶排序.鸽巢排序.归并排序等. 冒泡排序是一种简单的排序算法.它重复地走访过要排序的数列,一 ...

  8. java提供的默认list排序方法-转

    1.java提供的默认list排序方法 主要代码: List<String> list = new ArrayList();list.add("刘媛媛"); list. ...

  9. Flex Array内置排序方法的使用

    在Array类中,提供内置的排序方法.排序是在软件开发的过程中,经常遇到的问题.通过这些内置的方法,可以快速轻便的进行排序操作. Array类提供sort方法对Array实例进行排序.sort方法没有 ...

随机推荐

  1. Tomcat环境的搭建(web基础学习笔记一)

    一.下载和安装Tomcat服务器 下载Tomcat安装程序包:http://tomcat.apache.org/ 点击[Download]跳转到如下图所示的下载页面 二.点击左侧要下载的版本,选择To ...

  2. 导入maven项目出现 Unsupported IClasspathEntry kind=4

    Unsupported IClasspathEntry kind=4 这个异常会导致项目无法使用spring ide启动 来自:http://blog.csdn.net/kongqz/article/ ...

  3. linux的fork()函数-进程控制

    进程作为构成系统的基本细胞,不仅是系统中独立活动的实体,而且是独立竞争资源的基本实体.它要经历创建.执行.等待.终止等一系列过程. 一.fork入门知识(转载) 一个进程,包括代码.数据和分配给进程的 ...

  4. yml 配置文件注入

    配置文件 JavaBean 自动提示 测试

  5. Linux系统重装与还原

    当初第一次装ubuntu系统时,对文件系统的构成还不太了解,所以在分区的时候给home的分区特别小,导致后期软件都装不进去.说磁盘已满.所以想对系统又一次分区. 上网找了资料,都说用GParted这个 ...

  6. HDU 5402 Travelling Salesman Problem(棋盘染色 构造 多校啊)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5402 Problem Description Teacher Mai is in a maze wit ...

  7. ab,qps,服务器性能压力

    ab,qps,服务器性能压力   作者及来源: 陳聽溪 - 博客园    收藏到→_→:   摘要: ab,qps,服务器性能压力    http://www.makaidong.com/%E5%8D ...

  8. 用 Qt Creator 开发非 Qt 的 C/C++ 程序

    在Windows还是习惯用VS2005但是现在到了Linux下,开发起来C/C++程序就没有那么得心应手的IDE了.虽然很多人推荐E开头那个主要作为Java开发的IDE,不过安上插件后感觉不大好,一个 ...

  9. 雪球、牛股王这种股票类App 到底能否帮你赚到钱?

    核心观点 股民这个大群体,是需要区分对待的:其中包含一小部分有自己独立判断能力的投资者和一大群没有自己判断能力(尽管他们经常觉得自己有)的普通散户. 当前的互联网证券类App,确实很难保证帮股民赚到钱 ...

  10. Go 1.5keyword搜索文件夹、文件、文件内容_修复一个小BUG

    package main import ( "bufio" "bytes" "flag" "fmt" "io& ...