zoukankan      html  css  js  c++  java
  • Array中对象的排序

    1.子母排序

    NSArray *kArrSort = [_dic allKeys]; //这里是字母数组:,g,a,b.y,m……

    NSArray *resultkArrSort = [kArrSort sortedArrayUsingComparator:^NSComparisonResult(id obj1, id obj2) {

                                           return [obj1 compare:obj2   options:NSNumericSearch];

                                            }];

    NSLog(@"%@",resultkArrSort);

    2.数值排序

    // sortedArrayUsingComparator:方法并不会改变array数组内部的顺序

    NSArray *sortedArray = [array sortedArrayUsingComparator:^NSComparisonResult(NSNumber *obj1, NSNumber *obj2) {

                                        if ([obj1 intValue] < [obj2 intValue]) {

                                             return NSOrderedDescending;

                                       } else {

                                            return NSOrderedAscending;

                                     } }];

    NSLog(@"%@", sortedArray);

    3.使用NSDescriptor进行排序

    我们将要排序的对象是一个Persion类,如下定义:

    1. @interface Person : NSObject 
    2. @property (nonatomic, copy) NSString *name; 
    3. @property (nonatomic, copy) NSString *surname; 
    4. @property (nonatomic, strong) NSDate *dateOfBirth; 
    5. @end 

    而数组中包含如下内容:

    1. Smith John 03/01/1984 
    2. Andersen Jane 16/03/1979 
    3. Clark Anne 13/09/1995 
    4. Smith David 19/07/1981 
    5. Johnson Rose 22/02/1989 
    1. NSSortDescriptor *firstDescriptor = [[NSSortDescriptor alloc] initWithKey:@"surname" ascending:YES]; 
    2. NSSortDescriptor *secondDescriptor = [[NSSortDescriptor alloc] initWithKey:@"name" ascending:YES]; 
    3.  
    4. NSArray *sortDescriptors = [NSArray arrayWithObjects:firstDescriptor, secondDescriptor, nil]; 
    5.  
    6. NSArray *sortedArray = [self.persons sortedArrayUsingDescriptors:sortDescriptors]; 

    上面代码的排序结果如下所示:

    1. Andersen Jane 
    2. Clark Anne 
    3. Johnson Rose 
    4. Smith David 
    5. Smith John 
  • 相关阅读:
    MySQL修改时区的方法小结
    MYSQL日期 字符串 时间戳互转
    2017php经典面试题
    PHP获得真实客户端的真实IP REMOTE_ADDR,HTTP_CLIENT_IP,HTTP_X_FORWARDED_FOR
    开放api接口签名验证
    MySql之ALTER命令用法详细解读(转)
    easyUI datagrid 清空
    webApi文档好帮手-apidoc使用教程
    驼峰命名和下划线命名互转php实现
    SQL Server 数据导入Mysql详细教程
  • 原文地址:https://www.cnblogs.com/zhou--fei/p/5227171.html
Copyright © 2011-2022 走看看