- 不要等到明天井辜,明天太遙遠,今天就行動。
須讀:看完該文章你能做什么?
NSArray的排序(普通排序,給對象的屬性排序)
學習前:你必須會什么?(在這里我已經(jīng)默認你具備C語言的基礎(chǔ)了)
NSArray的基本使用
一忽你、本章筆記
一、數(shù)組的排序
- (NSArray<ObjectType> *)sortedArrayUsingSelector:(SEL)comparator;
二臂容、數(shù)組的對象排序(比如對 person里面的一個屬性進行排序)
- (NSArray<ObjectType> *)sortedArrayWithOptions:(NSSortOptions)opts usingComparator:(NSComparator NS_NOESCAPE)cmptr NS_AVAILABLE(10_6, 4_0);
三科雳、什么是升序、降序
升序就是從小到大脓杉,從低到高排糟秘。
降序就是從大到小,從高到低排球散。
二尿赚、code
main.m
#pragma mark 04-數(shù)組排序
#pragma mark 概念
/*
一、數(shù)組的排序
- (NSArray<ObjectType> *)sortedArrayUsingSelector:(SEL)comparator;
二、數(shù)組的對象排序(比如對 person里面的一個屬性進行排序)
- (NSArray<ObjectType> *)sortedArrayWithOptions:(NSSortOptions)opts usingComparator:(NSComparator NS_NOESCAPE)cmptr NS_AVAILABLE(10_6, 4_0);
三凌净、什么是升序悲龟、降序
升序就是從小到大,從低到高排冰寻。
降序就是從大到小须教,從高到低排。
*/
#pragma mark - 代碼
#import <Foundation/Foundation.h>
#pragma mark 類
#import "Person.h"
#pragma mark - main函數(shù)
int main(int argc, const char * argv[])
{
NSArray *arr = @[@20,@23,@11,@55,@12];
// 注意 : 想使用compare方法對數(shù)組的元素進行排序, 那么數(shù)組中的元素必須是Foundation框架的對象, 也就是不能是自定義對象
NSArray *newArr = [arr sortedArrayUsingSelector:@selector(compare:)];
NSLog(@"排序前 :%@",arr);
NSLog(@"排序后 :%@",newArr);
#warning 不能使用 compare: 方法對自定義進行排序
Person *p1 = [Person new];
p1.age = 10;
Person *p2 = [Person new];
p2.age = 20;
Person *p3 = [Person new];
p3.age = 5;
Person *p4 = [Person new];
p4.age = 8;
NSArray *arr1 = @[p1,p2,p3,p4];
NSLog(@"排序前 :%@",arr1);
//按照人的年齡 進行排序
// Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '-[Person compare:]: unrecognized selector sent to instance 0x102b00080'
// NSArray *newArr2 = [arr1 sortedArrayUsingSelector:@selector(compare:)];
// NSSortConcurrent = (1UL << 0), // 并行 多線程
// NSSortStable = (1UL << 4), // 安全
// 排序算法
// 該方法默認按照升序排序
NSArray *newArr2 = [arr1 sortedArrayWithOptions:NSSortStable usingComparator:^NSComparisonResult(Person *obj1, Person * obj2) {
// 每次調(diào)用該block都會 取出數(shù)組中的兩個元素 給我們
// 二分排序
NSLog(@"obj1 = %@, obj2 = %@",obj1,obj2);
// return obj1.age > obj2.age; // 升序 升序就是從小到大斩芭,從低到高排轻腺。
return obj1.age < obj2.age; // 降序 降序就是從大到小,從高到低排划乖。
}];
NSLog(@"排序后 :%@",newArr2);
return 0;
}
Person
>>>.h
#import <Foundation/Foundation.h>
@interface Person : NSObject
@property (nonatomic,assign) int age;
@end
>>>.m
#import "Person.h"
@implementation Person
- (NSString *)description
{
return [NSString stringWithFormat:@"age = %i",_age];
}
@end