sortedArrayUsingComparator是一个block函数,废话不多上例子。
详细例子:
1.对模型数组进行排序
//模型数组排序,scoreArray是一个存放分数与姓名的模型数组,我们要对积分进行升序排序
NSArray *array = [self.scoreArray sortedArrayUsingComparator:^NSComparisonResult(id obj1, id obj2) {
//模型数组的类ScoreModel
ScoreModel *pModel1 = obj1;
ScoreModel *pModel2 = obj2;
//这里我们要将key值的String转化为intValue进行比较
int keyNumber1 = [pModel1.score intValue];
int keyNumber2 = [pModel2.score intValue];
//按照分数排序 大到小
if (keyNumber1 < keyNumber2) { //不使用intValue比较无效(integerValue也行)
return NSOrderedDescending;//降序
}else if (keyNumber1 > keyNumber2){
return NSOrderedAscending;//升序
}else {
return NSOrderedSame;//相等
}
}];
数组array就是我们经过升序排序(根据score大小)的模型数组
如果要对姓名排序,我们可以通过ASCII进行排序,不过别拿String来进行比较排序就是了(也许能,只是我不会...)
2.对数组进行排序
NSArray *numberArray = @[@4,@5,@2,@6,@3,@7,@8];
//我们对元素进行降序排序
NSArray *array = [numberArray sortedArrayUsingComparator:^NSComparisonResult(id obj1, id obj2){
NSNumber *number1 = obj1;
NSNumber *number2 = obj2;
//比较integerValue
if ([number1 integerValue] > [number2 integerValue]){
return NSOrderedDescending;
}else if{[number1 integerValue] < [number2 integerValue]}
return NSOrderedAscending;
}else{
return NSOrderedSame;
}
}];
两个例子大同小异
对于sortedArrayUsingComparator函数,知乎上有过这么一个回答:
sortedArrayUsingComparator这个方法本身就是按递增的方式排序,而怎么定义递增,就看是Comparator怎么设计的了
查看文档有
NSOrderedAscending
The left operand is smaller than the right operand.
NSOrderedSame
The two operands are equal.
NSOrderedDescending
The left operand is greater than the right operand.
如果你期望的是值小的在前而值大的在后,则可以在比较的时候返回NSOrderedAscending(-1),否则,就是NSOrderedDescending(1)。