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知识点的更多相关文章

  1. iOS - OC NSSet 集合

    前言 NSSet:集合 @interface NSSet<__covariant ObjectType> : NSObject <NSCopying, NSMutableCopyin ...

  2. OC中NSDictionary(字典)、NSMutableDictionary(可变字典)、NSSet(集合)、NSMutableSet(可变集合)得常用方法

    字典用于保存具有映射关系数据的集合 一个key—value对认为是一个条目(entry),字典是存储key—value对的容器 与数组不同,字典靠key存取元素 key不能重复,value必须是对象 ...

  3. NSSet、NSMutableSet基本用法

    NSSet.NSMutableSet基本用法 在Foundation框架中,提供了NSSet类,它是一组单值对象的集合,且NSSet实例中元素是无序,同一个对象只能保存一个. 一.不可变集合NSSet ...

  4. NSSet、NSMutableSet

    NSSet和NSArray功能性质一样,用于存储对象,属于集合:只能添加cocoa对象,基本数据类型需要装箱. NSSet . NSMutableSet是无序的集合,在内存中存储方式是不连续的,而NS ...

  5. NSSet和NSMutableSet 确保数据的唯一性--备

    NSSet和NSMutableSet是无序的, 但是它保证数据的唯一性.当插入相同的数据时,不会有任何效果.从内部实现来说是hash表,所以可以常数时间内查找一个数据. 1.NSSet的使用 [NSS ...

  6. ios 集合总结

    NSArray 用于对象有序集合(相当于是数组) 它有两个限制: 1. 它只能存储objective-c的对象,但不能存储C中的基本数据类型,如int , float, enum, struct等. ...

  7. [Objective-C] 010_Foundation框架之NSSet与NSMutableSet

    在Cocoa Foundation中的NSSet和NSMutableSet ,和NSArray功能性质一样,用于存储对象属于集合.但是NSSet和NSMutableSet是无序的, 保证数据的唯一性, ...

  8. iOS 集合的深复制与浅复制

    概念 对象拷贝有两种方式:浅复制和深复制.顾名思义,浅复制,并不拷贝对象本身,仅仅是拷贝指向对象的指针:深复制是直接拷贝整个对象内存到另一块内存中. 一图以蔽之 再简单些说:浅复制就是指针拷贝:深复制 ...

  9. ios集合

    Foundation framework中用于收集cocoa对象(NSObject对象)的三种集合分别是: NSArray 用于对象有序集合(数组) NSSet 用于对象无序集合 (集合) NSDic ...

随机推荐

  1. 用Python开始机器学习(7:逻辑回归分类) --好!!

    from : http://blog.csdn.net/lsldd/article/details/41551797 在本系列文章中提到过用Python开始机器学习(3:数据拟合与广义线性回归)中提到 ...

  2. Git--用git建立code库

    利用点时间,把自己这段时间使用git的工具的内容,使用过程中遇到的问题都梳理下.首先我们建立一个文件库(基于Ubuntu系统): 1.必须要安装: [html]  view plain copy   ...

  3. jackson反序列化时忽略不需要的字段

    有时候,如果数据库表中增加一个字段,但返回的JSON字符串中含有我们并不需要的字段,那么当对应的实体类中不含有该字段时,会抛出一个异常,告诉你有些字段没有在实体类中找到.解决办法很简单,在声明Obje ...

  4. Sphinx全文索引 第一节

    1 使用场景:用来解决站内搜索的一些应用场景. 网站中的搜索(站内搜索) 系统后台中的搜索 第一种方式:PHP——>MySQL 第二种方式:MySQL<——>Sphinx:PHP—— ...

  5. HMM 自学教程(七)前向后向算法

    本系列文章摘自 52nlp(我爱自然语言处理: http://www.52nlp.cn/),原文链接在 HMM 学习最佳范例,这是针对 国外网站上一个 HMM 教程 的翻译,作者功底很深,翻译得很精彩 ...

  6. Linux - 获取Shell命令帮助信息

    Manual Page Chapter List 1:所有用户可以操作的指令或可执行文件 2:系统核心调用的函数与工具 3:子调用,常用的函数与函数库 4:设备,硬件文件说明,通常是/dev/的文件 ...

  7. Android 学习笔记之AndBase框架学习(二) 使用封装好的进度框,Toast框,弹出框,确认框...

    PS:渐渐明白,在实验室呆三年都不如在企业呆一年... 学习内容: 1.使用AbActivity内部封装的方法实现进度框,Toast框,弹出框,确认框...   AndBase中AbActivity封 ...

  8. 专题——web.xml 中 url-pattern

    一.映射什么? 一个请求发送到 servlet 容器,servlet 容器会将当前请求的 url 路径减去 协议.端口号.contextPath,剩下 servletPath 就是用来做 url-pa ...

  9. sprint3 总结

    sprint3 本次的主要任务是找项目中的bug,并与客户不断地沟通以满足客户的要求.队友主要负责找项目中的bug或提出一些建议.我主要是负责与客户沟通和修复bug.总的来说进展还算顺利. 团队贡献分 ...

  10. ANT自动打包U3D安卓项目研究笔记

    概述 因项目使用Atlassian Stash作为项目源码管理端,且其支持Ant命令自动编译,可使其根据最新的代码自动打包,故产生该研究Ant打包的任务.在此将研究过程及一些相关知识整理记录在此. 本 ...