一,enumerateObjectsUsingBlock 实现数组遍历
NSArray *arr = [NSArray arrayWithObjects:@"1",@"2",@"3",@"4",@"5", nil];
[arr enumerateObjectsUsingBlock:^(id _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) {
NSLog(@"Before ------- %ld", idx);
if (idx == 1) {
*stop = YES;
return;
}
NSLog(@"After ------- %ld", idx);
}];
1.只用 *stop = YES; 本次循环执行完成,结束数组的循环,不再进行下一个idx的遍历
2.只用 return; 本次循环到此中断(不执行本次循环剩余的代码),继续进行下一个idx的遍历,相当于for循环中continue的用法
3.*stop = YES; 和 return; 连用,不执行本次循环剩余的代码,而且到此idx为止,结束数组的循环Block,相当于for循环中break的用法
二,sortedArrayUsingComparator 实现数组排序
NSArray *list = [NSArray arrayWithObjects:@"2",@"1",@"5",@"4", nil];
NSArray *tArray = [list sortedArrayUsingComparator:^NSComparisonResult(id _Nonnull obj1, id _Nonnull obj2) {
if ([obj1 integerValue] > [obj2 integerValue]) {
return NSOrderedDescending;
}
return NSOrderedAscending;
}];
注释:对于生序/降序容易混淆的同学,可以这样理解:无论比较符号是大于还是小于,只看return的值是NSOrderedDescending还是NSOrderedAscending,
如果obj1>obj2, 返回Descending,意为倒过来排序,也就是说obj2要放在前面,小的在前,所以是升序;
如果obj1>obj2, 返回Ascending,意为正序排列,也就是说obj1放在前面,大的在前,所以是降序;
更简明的总结为一句话:两个值做比较,根据return的是正序还是倒序,判断是大的在前还是小的在前,由此确定是降序还是生序
三,实现数组倒置
NSArray *list = [NSArray arrayWithObjects:@"2",@"1",@"5",@"4", nil];
NSArray *tArray = [list sortedArrayUsingComparator:^NSComparisonResult(id _Nonnull obj1, id _Nonnull obj2) {
return NSOrderedDescending;
// return NSOrderedAscending;
}];
注释:如果不做元素的比较,而直接返回NSOrderedDescending / NSOrderedAscending,也就意味着执行倒序 / 正序(正序就是保持现在的排序不变)
以此数组为例,执行NSOrderedDescending,tArray内元素的顺序会整个倒置,成为[@"4",@"5",@"1",@"2"]