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. NGUI 界面自适应

    关于 NGUI 的界面自动适应不同的手机分辨率,网上已经够多的了.如果你点进了这个网页,推荐一下这一篇吧: http://www.xuanyusong.com/archives/2536 下面是我自己 ...

  2. poj 3486 A Simple Problem with Integers(树状数组第三种模板改段求段)

    /* 树状数组第三种模板(改段求段)不解释! 不明白的点这里:here! */ #include<iostream> #include<cstring> #include< ...

  3. 【转载】两个排序数组的中位数 / 第K大元素(Median of Two Sorted Arrays)

    转自 http://blog.csdn.net/zxzxy1988/article/details/8587244 给定两个已经排序好的数组(可能为空),找到两者所有元素中第k大的元素.另外一种更加具 ...

  4. JS微信分享不好写?来封装一下

    微信开发这块,作为开发工程师来说,一般是避免不了的,也好像发现一些朋友写微信分享都是在每个页面一大把一大把的代码. 代码冗余,即便是复制过来再改也很麻烦. 之前自己封装了一下js,今天来分享一下,希望 ...

  5. 开源一个基于天天团购的团购app

    可能大家都知道天天团购开源系统,一个做团购的开源项目很赞,前些日子做了基于天天团购系统做的团购客户端和移动端服务器!源代码放出,有了解的可以看看,希望收益! 先说服务器:app的服务器,基于天天团购的 ...

  6. javascript中的数组扩展(一)

     javascript中的数组扩展(一) 随着学习的深入,发现需要学习的关于数组的内容也越来越多,后面将会慢慢归纳,有的是对前面的强化,有些则是关于前面的补充. 一.数组的本质    数组是按照次序排 ...

  7. UWP开发入门(十四)—— UserControl中Adaptive UI的小技巧

    本篇我们通过绘制一个非常简单的UserControl控件,来分享一下对Adaptive UI的理解及一些图形绘制的技巧. 现在流行的APP都少不了精致的用户头像,首先假设我们需要绘制如下的图形作为默认 ...

  8. .Net魔法堂:AssemblyInfo.cs文件详解

    一.前言 .net工程的Properties文件夹下自动生成一个名为AssemblyInfo.cs的文件,一般情况下我们很少直接改动该文件.但我们实际上通过另一个形式操作该文件.那就是通过在鼠标右键点 ...

  9. 注意力机制(Attention Mechanism)在自然语言处理中的应用

    注意力机制(Attention Mechanism)在自然语言处理中的应用 近年来,深度学习的研究越来越深入,在各个领域也都获得了不少突破性的进展.基于注意力(attention)机制的神经网络成为了 ...

  10. 转贴:JavaScript实现Ajax请求简单示例

    转至:https://my.oschina.net/u/658145/blog/167651 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 ...