NSArary自定义对象排序 NSComparator, compare
reference from :http://mobile.51cto.com/hot-434804.htm
1.构建Person类
Person.h
@interface Person : NSObject
@property (nonatomic, copy) NSString *name;
@property (nonatomic, copy) NSString *surname;
@property (nonatomic, strong) NSDate *dateOfBirth;
@end
2. 初始化ObjSort对象排序功能,包含一个NSArray数组,数组元素为自定义Person
ObjSort.h
/**
* 对NSArray自定义对象排序类
*/
@interface ObjSort : NSObject
-(void)personsSort_NSComparator;//NSComparator比较器
@end
ObjSort.m
@interface ObjSort()
@property (nonatomic, strong) NSMutableArray *personObjs;//存储了若干个Person类对象的数组
@end @implementation ObjSort /**
* 初始化对象
* 初始化NSMutableArray数组personObjs的初始内容, 包装Person类对象
*/
-(instancetype)init{
self = [super init];
if (self == nil) {
return nil;
} NSDateFormatter *formatter = [[NSDateFormatter alloc] init];
[formatter setDateFormat:@"dd/MM/yyyy"]; Person *person[5];
for(int i=0; i<5; i++){
person[i] = [[Person alloc] init];
} person[0].name = @"Smith";
person[0].surname = @"John";
person[0].dateOfBirth = [formatter dateFromString:@"03/01/1984"]; person[1].name = @"Andersen";
person[1].surname = @"Jane";
person[1].dateOfBirth = [formatter dateFromString:@"16/03/1979"]; person[2].name = @"Clark";
person[2].surname = @"Anne";
person[2].dateOfBirth = [formatter dateFromString:@"13/09/1995"]; person[3].name = @"Smith";
person[3].surname = @"David";
person[3].dateOfBirth = [formatter dateFromString:@"19/07/1981"]; person[4].name = @"Johnson";
person[4].surname = @"Rose";
person[4].dateOfBirth = [formatter dateFromString:@"22/02/1989"]; if (_personObjs==nil) {
_personObjs = [[NSMutableArray alloc] initWithCapacity:5];
}
for (int i=0; i<5; i++) {
[_personObjs addObject:person[i]];
} [self showPersons:_personObjs];
return self;
} /**
* 日志打印输出当前NSArray内容
*/
-(void)showPersons:(NSArray *)array{
Person *person; if (_personObjs == nil) {
NSLog(@"nil");
} for (int i =0; i< [array count]; i++) {
person = [array objectAtIndex:i];
if ([person isKindOfClass:[Person class]]) {
NSLog(@"---Person %d---", i);
NSLog(@"Name: %@", person.name);
NSLog(@"Surname: %@", person.surname);
NSLog(@"DateOfBirth: %@", person.dateOfBirth);
}
else{
NSLog(@"Object in personObjs is not Person class object.");
}
}
NSLog(@"All person print over.\n\n");
}
方法一:NSComparator block + NSArray的 sortedArrayUsingSelector
在ObjSort中实现方法personsSort_NSComparator
/**
* 采用NSComparator比较的排序方法
*/
-(void)personsSort_NSComparator{ NSComparator sortBlock = ^(Person *p1 , Person *p2){
NSComparisonResult r1 = [p1.name compare:p2.name];
if(r1 != NSOrderedSame){
return r1;
}else {
NSComparisonResult r2 = [p1.surname compare:p2.surname];
if (r2 != NSOrderedSame)
return r2;
else
return [p1.dateOfBirth compare:p2.dateOfBirth];
}
};
NSArray *personList = [self.personObjs sortedArrayUsingComparator:sortBlock];
NSArray *personList = [self.personObjs sortedArrayUsingSelector:@selector(compare:)];
[self showPersons:personList];
}
方法二:利用对象的自定义方法compare:
Person.m中添加
-(NSComparisonResult)compare:(Person *)otherPerson{
NSComparisonResult r1 = [self.name compare:otherPerson.name];
if(r1 != NSOrderedSame){
return r1;
}else {
NSComparisonResult r2 = [self.surname compare:otherPerson.surname];
if (r2 != NSOrderedSame)
return r2;
else
return [self.dateOfBirth compare:otherPerson.dateOfBirth];
}
return [self.name compare:otherPerson.name];
}
ObjSort.m中添加
/**
* 采用自定义对象自定义函数compare进行NSArray排序
*/
-(void)personsSort_CustomCompare{
NSArray *personList = [self.personObjs sortedArrayUsingSelector:@selector(compare:)];
[self showPersons:personList];
}
在ObjSort.h中添加响应的接口
/**
* 对NSArray自定义对象排序类
*/
@interface ObjSort : NSObject
-(void)personsSort_NSComparator;//NSComparator比较器
-(void)personsSort_CustomCompare;//对象自定义比较方法Compare
@end
最后,在main.m(排序调用处)添加
ObjSort *objSort = [[ObjSort alloc] init];
[objSort personsSort_NSComparator];
方法一结果
---Person ---
Name: Smith
Surname: John
DateOfBirth: -- :: +
---Person ---
Name: Andersen
Surname: Jane
DateOfBirth: -- :: +
---Person ---
Name: Clark
Surname: Anne
DateOfBirth: -- :: +
---Person ---
Name: Smith
Surname: David
DateOfBirth: -- :: +
---Person ---
Name: Johnson
Surname: Rose
DateOfBirth: -- :: +
All person print over. ---Person ---
Name: Andersen
Surname: Jane
DateOfBirth: -- :: +
---Person ---
Name: Clark
Surname: Anne
DateOfBirth: -- :: +
---Person ---
Name: Johnson
Surname: Rose
DateOfBirth: -- :: +
---Person ---
Name: Smith
Surname: David
DateOfBirth: -- :: +
---Person ---
Name: Smith
Surname: John
DateOfBirth: -- :: +
All person print over.
方法二结果
---Person ---
Name: Smith
Surname: John
DateOfBirth: -- :: +
---Person ---
Name: Andersen
Surname: Jane
DateOfBirth: -- :: +
---Person ---
Name: Clark
Surname: Anne
DateOfBirth: -- :: +
---Person ---
Name: Smith
Surname: David
DateOfBirth: -- :: +
---Person ---
Name: Johnson
Surname: Rose
DateOfBirth: -- :: +
All person print over. ---Person ---
Name: Andersen
Surname: Jane
DateOfBirth: -- :: +
---Person ---
Name: Clark
Surname: Anne
DateOfBirth: -- :: +
---Person ---
Name: Johnson
Surname: Rose
DateOfBirth: -- :: +
---Person ---
Name: Smith
Surname: David
DateOfBirth: -- :: +
---Person ---
Name: Smith
Surname: John
DateOfBirth: -- :: +
All person print over.
NSArary自定义对象排序 NSComparator, compare的更多相关文章
- ht-8 对arrayList中的自定义对象排序( Collections.sort(List<T> list, Comparator<? super T> c))
package com.iotek.set; import java.util.ArrayList; import java.util.Collections; import java.util.Co ...
- Object-C中的排序和Compare陷阱
来源:http://m.blog.csdn.net/blog/u011883764/38868097 Date : 2015-12-24 一.Compare陷阱 NSString有多个compare相 ...
- Java基础知识强化之集合框架笔记69:Collections类之ArrayList存储自自定义对象并排序的案例
1. ArrayList存储自自定义对象并排序的案例: ArrayList存储自自定义对象,并使用Collections对ArrayList存储基本包装类的元素排序. 2. 代码实现: (1)Stud ...
- Java:集合,对列表(List)中的自定义对象按属性(字段)排序(正序、倒序)的方法
1. 要求 对列表(List)中的自定义对象,要求能够按照对象的属性(字段)进行排序(正序.倒序). 如:用户对象(Member)有用户名(username).级别(level).出生日期(birth ...
- TreeSet 比较器排序 自定义对象
package cn.itcast.day21.treeset2; import java.util.Comparator; import java.util.TreeSet; /* * TreeSe ...
- TreeMap 底层是红黑树 排序是根据key值进行的 添加元素时异常 Comparable异常 Comparator比较自定义对象放在键的位置
package com.swift; import java.util.Comparator; import java.util.HashMap; import java.util.Iterator; ...
- Java基础知识强化之集合框架笔记46:Set集合之TreeSet存储自定义对象并遍历练习2(自然排序:Comparable)
1. TreeSet存储自定义对象并遍历练习2: (1)Student.java package cn.itcast_06; /* * 如果一个类的元素要想能够进行自然排序,就必须实现自然排序接口 * ...
- Java基础知识强化之集合框架笔记45:Set集合之TreeSet存储自定义对象并遍历练习1(自然排序:Comparable)
1. 自然排序: TreeSet会调用集合元素的compareTo(Object obj)方法来比较元素之间的大小关系,然后将集合元素按照升序排列,这种方式就是自然排序. Java中提供了一个Comp ...
- 《java入门第一季》之TreeSet存储自定义对象并保证排序和唯一
上一篇用一个简单的例子,介绍了treeset集合存储的内部过程,这里再完善其存储自定义对象保证唯一. 需求:A: * 自然排序,按照年龄从小到大排序 * B: * 成员变量值都相 ...
随机推荐
- WORKDIR 指定工作目录 每一个 RUN 都是启动一个容器、执行命令、然后提交存储层文件变更
WORKDIR 指定工作目录 格式为 WORKDIR <工作目录路径>. 使用 WORKDIR 指令可以来指定工作目录(或者称为当前目录),以后各层的当前目录就被改为指定的目录,如该目录不 ...
- Copy-On-Write容器(转载)
Copy-On-Write简称COW,是一种用于程序设计中的优化策略.其基本思路是,从一开始大家都在共享同一个内容,当某个人想要修改这个内容的时候,才会真正把内容Copy出去形成一个新的内容然后再改, ...
- locust --hellp
1. Locust简介 Locust是使用Python语言编写实现的开源性能测试工具,简洁.轻量.高效,并发机制基于gevent协程,可以实现单机模拟生成较高的并发压力. 官网:https://loc ...
- WebRTC之Android客户端
一.WebRTC的Android客户端搭建 1.libjingle_peerconnection_so.so 2.libjingle_peerconnection.jar 3.客户端源码一份(可以在g ...
- 理解WPF中的视觉树和逻辑树
轉載地址:http://blog.csdn.net/changtianshuiyue/article/details/26981797 理解WPF中的视觉树和逻辑树 Understanding th ...
- Java自学-集合框架 HashMap和Hashtable的区别
HashMap和Hashtable之间的区别 步骤 1 : HashMap和Hashtable的区别 HashMap和Hashtable都实现了Map接口,都是键值对保存数据的方式 区别1: Hash ...
- 了解 C++
C++的历史 C++由C语言发展演变而来,最初被称为"带类的C" 1983年正式取名为C++ 1998年11月被国籍标准化组织(ISO)批准为国际标准 2003年10月15日发布了 ...
- Navigating to current location ("/") is not allowed
main.js import Router from 'vue-router' // 这个是为了避免一个报错 const originalPush = Router.prototype.push; R ...
- 吴裕雄--天生自然TensorFlow2教程:误差计算
import tensorflow as tf y = tf.constant([1, 2, 3, 0, 2]) y = tf.one_hot(y, depth=4) # max_label=3种 y ...
- ubuntu16.04下安装docker和docker-compose
开始安装 由于apt官方库里的docker版本可能比较旧,所以先卸载可能存在的旧版本:$ sudo apt-get remove docker docker-engine docker-ce dock ...