IOS集合NSSet与NSMutableSet知识点
NSSet在实际应用中与NSArray区别不大,但是如果你希望查找NSArray中的某一个元素,则需要遍历整个数组,效率低下。而NSSet在查找某一特定的元素的时候则是根据hash算法直接找到此元素的位置,效率高。 NSSet是一个无序的,管理对个对象的集合类,最大特点是集合中不允许出现重复对象,和数学上的集合含义是一样的。除了无序,不许重复,其他功能和NSArray是一样的;需要注意的是:NSSet,NSArray里面只能添加cocoa对象,如果需要加入基本数据类型(int,float,BOOL,double等),需要将数据封装成NSNumber类型。主要是一些常见的操作,别外一些操作见其相应的文档,下面的代码部分还运用的第三方插件BlocksKit相结合;
1:NSSet一些常见的操作
NSSet *newSet=[NSSet setWithObjects:@"wujy",@"cnblogs",@"age",nil];
NSLog(@"set的个数为:%ld",[newSet count]); //不会按上面增加的顺序输入 所以NSSET是没有顺序
NSEnumerator *enumeratorset=[newSet objectEnumerator];
for (NSObject *obj in enumeratorset) {
NSLog(@"key为:%@",obj);
} //是否存在
BOOL isExict=[newSet containsObject:@"wujy"];
NSLog(@"是否存在:%d",isExict); //返回任意一个元素
NSString *anyObje=[newSet anyObject];
NSLog(@"返回任意一个元素:%@",anyObje); //判断是否包含这个元素 并还回
NSObject *memberObj=[newSet member:@"age"];
if (memberObj) {
NSLog(@"存在元素(age):%@",memberObj);
} //简便创建nsset
NSSet *twoSet=[[NSSet alloc] initWithArray:@[@,@,@,@"wujy"]]; //判断两个nsset是否相等
BOOL isEaual=[newSet isEqualToSet:twoSet];
NSLog(@"判断两个nsset是否相等(0):%d",isEaual); //判断两个nsset是否交集
BOOL isInterSects=[newSet intersectsSet:twoSet];
NSLog(@"判断两个nsset是否交集(1):%d",isInterSects); //Blocks NSSet *blockSet=[[NSSet alloc]initWithObjects:@,@,@,@,@,@,nil];
//遍历
[blockSet bk_each:^(id obj) {
NSLog(@"block遍历的值为:%@",obj);
}]; //过滤
NSSet *selectSet=[blockSet bk_select:^BOOL(id obj) {
BOOL select=[obj intValue]>?YES:NO;
return select;
}];
NSLog(@"过滤后的nsset(6,5,4):%@",selectSet); //过滤 只在第一个符合条件时就停止
NSSet *matchSet=[blockSet bk_match:^BOOL(id obj) {
BOOL select=[obj intValue]<?YES:NO;
return select;
}];
NSLog(@"matchSet过滤后的nsset(3):%@",matchSet); //取反过滤
NSSet *rejectSet=[blockSet bk_reject:^BOOL(id obj) {
BOOL select=[obj intValue]<?YES:NO;
return select;
}];
NSLog(@"取反过滤后的nsset(6,5,4):%@",rejectSet); //对各个项进行处理
NSSet *mapSet=[blockSet bk_map:^id(id obj) {
return @([obj intValue]+);
}];
NSLog(@"修改后的值为(7,3,6,2,5,4):%@",mapSet); //是否符合条件 返回bool
BOOL isSelected=[blockSet bk_any:^BOOL(id obj) {
BOOL select=[obj intValue]>?YES:NO;
return select;
}];
NSLog(@"%d符合条件1",isSelected); //判断是否所有的项都符合这个条件
BOOL allSelected=[blockSet bk_all:^BOOL(id obj) {
BOOL select=[obj intValue]>?YES:NO;
return select;
}];
NSLog(@"%d符合条件0",allSelected); //判断是否所有的项都不符合这个条件
BOOL noneSelected=[blockSet bk_none:^BOOL(id obj) {
BOOL select=[obj intValue]>?YES:NO;
return select;
}];
NSLog(@"%d符合条件1",noneSelected);
2:NSMutableSet一些常见的操作
//创建
NSMutableSet *mutableSet=[[NSMutableSet alloc]initWithCapacity:];
[mutableSet addObject:@];
[mutableSet addObjectsFromArray:@[@,@,@]];
NSLog(@"增加后的NSMutableSet(3,2,1,4):%@",mutableSet); //把nsset增加进去
[mutableSet unionSet:[NSSet setWithObjects:@,@,nil]];
NSLog(@"增加后的NSMutableSet(3,6,2,5,1,4):%@",mutableSet); //去除元素
[mutableSet removeObject:@];
NSLog(@"去除后的元素(3,6,2,1,4):%@",mutableSet); //删除nsset里面的
[mutableSet minusSet:[NSSet setWithObjects:@,@,nil]];
NSLog(@"去除后nsset的元素(3,6,4):%@",mutableSet); //nsset转化成nsmutableset
NSSet *newSet=[NSSet setWithObjects:@,@,@, nil];
NSMutableSet *newMutableSet=[NSMutableSet set];
[newMutableSet setSet:newSet];
NSLog(@"转换后的mutableset值为(12,10,11):%@",newMutableSet); //Blocks
//过滤
NSMutableSet *blockMutableSet=[[NSMutableSet alloc]initWithObjects:@,@,@,nil];
[blockMutableSet bk_performSelect:^BOOL(id obj) {
BOOL select=[obj intValue]>?YES:NO;
return select;
}];
NSLog(@"过滤后的nsmutableset(25,23):%@",blockMutableSet); //取反过滤
[blockMutableSet bk_performReject:^BOOL(id obj) {
BOOL select=[obj intValue]>?YES:NO;
return select;
}];
NSLog(@"取反过滤后的nsmutableset(23):%@",blockMutableSet); //对项进行修改
[blockMutableSet bk_performMap:^id(id obj) {
return @([obj intValue]+);
}];
NSLog(@"修改后的nsmutableset(24):%@",blockMutableSet);
3:指数集合(索引集合)NSIndexSet
//指数集合(索引集合)NSIndexSet
NSIndexSet * indexSet = [[NSIndexSet alloc] initWithIndexesInRange:NSMakeRange(, )]; //集合中的数字是123 //根据集合提取数组中指定位置的元素
NSArray * array = [[NSArray alloc] initWithObjects:@"one",@"two",@"three",@"four", nil];
NSArray * newArray = [array objectsAtIndexes:indexSet]; //返回@"two",@"three",@"four" //可变指数集合NSMutableIndexSet
NSMutableIndexSet *indexSet = [[NSMutableIndexSet alloc] init];
[indexSet addIndex:]
[indexSet addIndex:];
[indexSet addIndex:];
//通过集合获取数组中指定的元素
NSArray *array = [[NSArray alloc] initWithObjects:@"one",@"two",@"three",@"four",@"five",@"six", nil];
NSArray *newArray = [array objectsAtIndexes:indexSet]; //返回@"one",@"four",@"six"
最近有个妹子弄的一个关于扩大眼界跟内含的订阅号,每天都会更新一些深度内容,在这里如果你感兴趣也可以关注一下(嘿对美女跟知识感兴趣),当然可以关注后输入:github 会有我的微信号,如果有问题你也可以在那找到我;当然不感兴趣无视此信息;

IOS集合NSSet与NSMutableSet知识点的更多相关文章
- iOS - OC NSSet 集合
前言 NSSet:集合 @interface NSSet<__covariant ObjectType> : NSObject <NSCopying, NSMutableCopyin ...
- OC中NSDictionary(字典)、NSMutableDictionary(可变字典)、NSSet(集合)、NSMutableSet(可变集合)得常用方法
字典用于保存具有映射关系数据的集合 一个key—value对认为是一个条目(entry),字典是存储key—value对的容器 与数组不同,字典靠key存取元素 key不能重复,value必须是对象 ...
- NSSet、NSMutableSet基本用法
NSSet.NSMutableSet基本用法 在Foundation框架中,提供了NSSet类,它是一组单值对象的集合,且NSSet实例中元素是无序,同一个对象只能保存一个. 一.不可变集合NSSet ...
- NSSet、NSMutableSet
NSSet和NSArray功能性质一样,用于存储对象,属于集合:只能添加cocoa对象,基本数据类型需要装箱. NSSet . NSMutableSet是无序的集合,在内存中存储方式是不连续的,而NS ...
- NSSet和NSMutableSet 确保数据的唯一性--备
NSSet和NSMutableSet是无序的, 但是它保证数据的唯一性.当插入相同的数据时,不会有任何效果.从内部实现来说是hash表,所以可以常数时间内查找一个数据. 1.NSSet的使用 [NSS ...
- ios 集合总结
NSArray 用于对象有序集合(相当于是数组) 它有两个限制: 1. 它只能存储objective-c的对象,但不能存储C中的基本数据类型,如int , float, enum, struct等. ...
- [Objective-C] 010_Foundation框架之NSSet与NSMutableSet
在Cocoa Foundation中的NSSet和NSMutableSet ,和NSArray功能性质一样,用于存储对象属于集合.但是NSSet和NSMutableSet是无序的, 保证数据的唯一性, ...
- iOS 集合的深复制与浅复制
概念 对象拷贝有两种方式:浅复制和深复制.顾名思义,浅复制,并不拷贝对象本身,仅仅是拷贝指向对象的指针:深复制是直接拷贝整个对象内存到另一块内存中. 一图以蔽之 再简单些说:浅复制就是指针拷贝:深复制 ...
- ios集合
Foundation framework中用于收集cocoa对象(NSObject对象)的三种集合分别是: NSArray 用于对象有序集合(数组) NSSet 用于对象无序集合 (集合) NSDic ...
随机推荐
- 内存调试的东西D/dalvikvm( 809 ): GC_CONCURRENT freed
一般Java虚拟机要求支持verbosegc选项,输出详细的垃圾收集调试信息.dalvik虚拟机很安静的接受verbosegc选项,然后什么都不做.dalvik虚拟机使用自己的一套LOG机制来输出调试 ...
- repo: 创建local manifest以及如何添加app到CM/Android build系统中
The local manifest Creating a local manifest allows you to customize the list of repositories on you ...
- MyBatis知多少(11)企业数据库
企业数据库比应用程序数据库更大,其外部影响也更大.它们与其他系统之间存在更多的关系,包括依赖关系和被依赖关系.这些关系可能是Web应用程序与报表工具之间的,但也很有可 能是与其他的复杂系统和数据库的接 ...
- imagepng或imagejpeg浏览器无显示问题
可以先参考这篇文章,检查一下php的文件编码是否有bom 然而我并不是这个问题,后来想到或许是输出缓冲中有其它内容, 于是尝试 ob_clean();$imagepng($im);或//imagejp ...
- JS思维之路菜鸟也能有大能量(1)--模拟push
因为本系列文章属于思维类,所以不做基础方法的讲解. 任务:首先我定义了一个变量var arr = [0,1,2,3,4,5];我现在想模拟push方法在这个数组的5后面加东西,我们应该怎么做?给你5分 ...
- Linux动态库的搜索路径
下面是目录结构: pengdl@localhost:~$ tree test/test/├── fun.c├── Fun.h└── t1 └── main.c 1 directory, 3 fi ...
- Axure RP介绍
1.什么是原型设计?产品原型设计(Prototype Design)最基础的工作,就是结合批注.大量的说明以及流程图画框架图WireFrame,将自己的产品原型完整而准确的表述给 UI.UE.程序工程 ...
- 探秘重编译(Recompilations)(1/2)
这篇文章我想谈下SQL Server里一个非常重要的性能调优话题:重编译(Recompilations) .当你执行非常简单的存储过程(使用临时表)时,就会发生.今天我想奠定SQL Server里重编 ...
- HQueue:基于HBase的消息队列
HQueue:基于HBase的消息队列 凌柏 1. HQueue简介 HQueue是一淘搜索网页抓取离线系统团队基于HBase开发的一套分布式.持久化消息队列.它利用HTable存储消息数据 ...
- chrome开发者工具浅析--timeline
一.概述 ...