• 数组排序


    NSArray *beforeSortArray = [[NSArray alloc] initWithObjects:
                                    @{@"id":@"1"},
                                    @{@"id":@"3"},
                                    @{@"id":@"4"},
                                    @{@"id":@"7"},
                                    @{@"id":@"8"},
                                    @{@"id":@"2"},
                                    @{@"id":@"6"},
                                    @{@"id":@"5"},
                                    @{@"id":@"13"},
                                    @{@"id":@"15"},
                                    @{@"id":@"12"},
                                    @{@"id":@"20"},
                                    @{@"id":@"28"},
                                    @{@"id":@""}
                                    ,nil];
        NSLog(@"排序前:%@",beforeSortArray);
    
        //方法一
        NSSortDescriptor *sortDesc = [[NSSortDescriptor alloc] initWithKey:@"id" ascending:YES];
        NSArray *sortArray = [NSArray arrayWithObject:sortDesc];
        [beforeSortArray sortedArrayUsingDescriptors:sortArray];
        
        NSLog(@"第一次排序前原来的数组:%@", beforeSortArray);
        NSArray *newArray = [beforeSortArray sortedArrayUsingDescriptors:sortArray];
        NSLog(@"第一次排序后原来的数组:%@", beforeSortArray);//看排序的时候,原数组元素顺序会不会改变
        NSLog(@"第一次排序后:%@",newArray);//验证排序结果
        
        
        //方法二
        NSComparator cmptr = ^(id obj1, id obj2){
            if ([[obj1 objectForKey:@"id"] integerValue] > [[obj2 objectForKey:@"id"] integerValue]) {
                return (NSComparisonResult)NSOrderedDescending;
            }
            
            if ([[obj1 objectForKey:@"id"] integerValue] < [[obj2 objectForKey:@"id"] integerValue]) {
                return (NSComparisonResult)NSOrderedAscending;
            }
            return (NSComparisonResult)NSOrderedSame;
        };
        
        NSLog(@"第二次排序前原来的数组:%@", beforeSortArray);
        NSArray *afterSortArray = [beforeSortArray sortedArrayUsingComparator:cmptr];
        NSLog(@"第二次排序后原来的数组:%@", beforeSortArray);//看排序的时候,原数组元素顺序会不会改变
        NSLog(@"第二次排序后:%@",afterSortArray);//验证排序结果

    总结:排序的时候,原数组的顺序不会改变,第一次的排序结果其实并不理想,没有达到想要的效果;还是建议大家多用第二种方法吧,数组的排序还有其他的几种写法,我不太熟,所以就没有写了,希望大家能多交流

  • 相关阅读:
    C++ <cstring> 里的一些常用函数
    Hadoop_第一次作业
    线性回归理解和应用例子
    条款28 :避免返回handles指向对象内部成分
    条款25 :尽可能延后变量定义式的出现时间
    条款21 :必须返回对象时,别妄想返回其reference
    条款16:成对使用new和delete时要采用相同的形式
    条款22 :将成员变量声明为private
    条款13:以对象管理资源
    条款12:复制对象时勿忘其每一个成分
  • 原文地址:https://www.cnblogs.com/shidaying/p/4689864.html
Copyright © 2020-2023  润新知