NSArray:有序的集合,NSSet:无序的集合,散列存储。 但是NSSet保证数据的唯一性。当插入相同的数据时,不会有任何效果。从内部实现来说是hash表。NSMutableSet是NSSet的子类,是NSSet的可变形式。

NSSet、NSMutableSet

NSSet的使用
[NSSet setWithSet:(NSSet *)set]; 用另外一个set对象构造
[NSSet setWithArray:(NSArray *)array];用数组构造
[NSSet setWithObjects:...]:创建集合对象,并且初始化集合中的数值,结尾必需使用nil标志。
[set count] ; 得到这个结合对象的长度。
[set containsObject:...]: 判断这个集合中是否存在传入的对象,返回Bool值。
[set objectEnumerator]: 将集合放入迭代器。
[enumerator nextObject]:得到迭代器中的下一个节点数据,使用while遍历这个迭代器,方可遍历集合对象中的对象。
[set isEqualToSet:objset]:判断两个集合是否完全相等,返回Bool值。
[set isSubsetOfSet:objset]:判断集合中的所有数据是否都相等与objeset集合中,返回Bool值。
[set allObjects];

NSMutableSet继承NSSet,它可以使用NSSet的方法。

[NSMutableSet setWithCapacity:6]:创建可变集合对象,并且初始化长度为6。
[set addObject: obj] : 向集合中动态的添加对象。
[set removeObject:obj]:删除集合中的一个对象。
[set removeAllObjects]:删除集合中的所有对象。
[set unionSet:obj]:向集合中添加一个obj集合的所有数据。
[set minusSet:obj]:向集合中删除一个obj集合的所有数据。
[set intersectSet]:向集合中删除一个不包含obj集合的所有数据。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
intmain(intargc,constchar*argv[])
{
 
    @autoreleasepool{
 
        //定义一个NSSet
        NSSet*set1=[NSSet setWithObjects:@"str1",@"str2",@"str3",nil];
 
        //使用NSArray初始化一个NSSet
        NSArray*array=[[NSArrayalloc] initWithObjects:@"obj1",@"obj2",@"obj3",@"str1",nil];
        NSSet*set2=[NSSet setWithArray:array];
 
        //用另外一个set对象构造
        NSSet*set3=[NSSet setWithSet:set2];
 
        //可变长度的集合
        NSMutableSet*set4=[NSMutableSet setWithSet:set3];
 
        //在可变集合中添加和移除对象
        [set4 addObject:@"obj4"];
        [set4 removeObject:@"obj2"];
 
        //获取这个结合对象的长度
        NSLog(@"size of set1:%lu",[set1 count]);
 
        //判断是否含有某个对象
        if([set3 containsObject:@"str1"])
            NSLog(@"set3 包含 str1");
         else
            NSLog(@"set3 不包含 str1");
 
        //判断set1 是否等于set2
        if([set1 isEqualToSet:set2])
            NSLog(@"set1 等于 set2");
        else
            NSLog(@"set1 不等于 set2");
 
        //判断set1 是否是set2的子集合
        if([set1 isSubsetOfSet:set2])
            NSLog(@"set1 是 set2的子集合");
        else
            NSLog(@"set1 不是 set2的子集合");
 
        //获取两个集合的交集
        [set1 intersectsSet:set2];
 
        //获取两个集合的并集
        [set4 unionSet:set3];
 
        //迭代遍历
        for(NSObject*object inset4){
             NSLog(@"set4里的对象:%@",object);
        }
 
        //使用NSEnumerator迭代遍历
        NSEnumerator*enumerator=[set4 objectEnumerator];
        for(NSObject*objectinenumerator){
            NSLog(@"set4里的对象:%@",object);
        }
    }
    return0;
}
NSIndexSet

NSIndexSet类和它的可变副本(NSMutableIndexSet)表示一个唯一的无符号整数的集合。这个类用于存储有序的索引到某种数据结构。例如,给定一个NSArray对象,你可以使用该数组中的索引,以确定对象的一个子集。

1
2
3
4
5
6
7
8
9
10
11
12
13
NSIndexSet*indexSet1=[NSIndexSet indexSetWithIndexesInRange:NSMakeRange(1,3)];
 
NSMutableIndexSet*indexSet2=[NSMutableIndexSetindexSet];
[indexSet addIndex:2];
[indexSet addIndex:5];
[indexSet addIndex:8];
 
//列出NSIndexSet的值
unsignedindex;
for(index=[indexSet firstIndex];
     index!=NSNotFound;index=[indexSet indexGreaterThanIndex: index])  {
    …
}

NSIndexSet的一些方法

+(NSIndexSet) indexSet   创建一个空的索集合
-(BOOL) containIndex:idx 如果索引集合包含索引idx,则返回YES,否则返回NO
-(NSUinteger) count 返回索引集合中索引的数量
-(NSUinteger) firstIndex 返回集合中的第一个索引,如何集合为空,则返回NSNotFound
-(NSUinteger) indexLessThanIndex:idx
返回集合中小于idx的最接近的索引,如果没有小于idx的索引,则返回NSNotFound.类似indexLessOrEuqalToIndex:、
indexGreaterThanIndex和indexGreaterThanOrEqualIndex:
-(NSIndexSet *)
indexesPassingTest:(BOOL)(^)(NSUinteger idx,BOOL *stop) block
 区块应用在集合中的每个元素。idx添加到了NSIndexSet中返回YES,否则返回NO。设置指针变量stop为YES,表示中断处理。

集合对象(NSSet,NSMutableSet,NSIndexSet)的更多相关文章

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

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

  2. NSDictionary NSMutableDictionary NSSet NSMutableSet

    //description只是返回了一个字符串 //    [person description]; //        //如果想要打印需要NSLog //    NSLog(@"%@& ...

  3. Objective-c 集合对象

    集合(NSSet)是一组单值对象的组合,集合对象的操作包括:搜索,添加,删除集合中的成员(可变集合的功能),比较两个集合,计算两个集合的交集,并集等. 下面来看下(NSSet)的方法: 1)集合的构建 ...

  4. Asp.net MVC中提交集合对象,实现Model绑定

    Asp.net MVC中的Model自动绑定功能,方便了我们对于request中的数据的处理, 从客户端的请求数据,自动地以Action方法参数的形式呈现.有时候我们的Action方法中想要接收数组类 ...

  5. Set集合对象比较两个元素的方法

    Set集合对象比较两个元素的方法并不是根据“equals()”方法的返回值来比较.而是用“hashCode()”方法来进行判断.只要两个元素的“hashCode()”方法的返回值相同,就认为两个元素相 ...

  6. 转载---Java集合对象的深度复制与普通复制

    原博文:http://blog.csdn.net/qq_29329775/article/details/49516247 最近在做算法作业时出现了错误,原因是没有弄清楚java集合的深度复制和浅度复 ...

  7. Objective-C之集合对象的内存管理

    *:first-child { margin-top: 0 !important; } body > *:last-child { margin-bottom: 0 !important; } ...

  8. Asp.net MVC中提交集合对象,实现Model绑定(转载)

    Asp.net MVC中的Model自动绑定功能,方便了我们对于request中的数据的处理, 从客户端的请求数据,自动地以Action方法参数的形式呈现.有时候我们的Action方法中想要接收数组类 ...

  9. JSon_零基础_004_将Set集合对象转换为JSon格式的对象字符串,返回给界面

    将Set集合对象转换为JSon格式的对象字符串,返回给界面 需要导入的jar包: 编写:servlet: package com.west.webcourse.servlet; import java ...

随机推荐

  1. 使用sprunge粘贴文字

    在irc里面请教的时候,需要输出很多文本,irc禁止输入多行文字. 使用sprunge可以返回一个网址,省去复制粘贴的麻烦. 1> 简单使用: command | curl -F "s ...

  2. POJ 3469 最小割 Dual Core CPU

    题意: 一个双核CPU上运行N个模块,每个模块在两个核上运行的费用分别为Ai和Bi. 同时,有M对模块需要进行数据交换,如果这两个模块不在同一个核上运行需要额外花费. 求运行N个模块的最小费用. 分析 ...

  3. CodeForces 570E DP Pig and Palindromes

    题意:给出一个n行m列的字符矩阵,从左上角走到右下角,每次只能往右或者往下走,求一共有多少种走法能得到回文串. 分析: 可以从两头开始考虑,每次只走一样字符的格子,这样得到的两个字符串拼起来之后就是一 ...

  4. 编译TensorFlow CPU指令集优化版

    编译TensorFlow CPU指令集优化版 如题,CPU指令集优化版,说的是针对某种特定的CPU型号进行过优化的版本.通常官方给的版本是没有针对特定CPU进行过优化的,有网友称,优化过的版本相比优化 ...

  5. Codeforces Round #470 (rated, Div. 2, based on VK Cup 2018 Round 1)

    A. Protect Sheep time limit per test 1 second memory limit per test 256 megabytes input standard inp ...

  6. Bootstrap-datepicker 用法

    <div class="input-group input-daterange"> <input type="text" id="s ...

  7. Python Mysql学习总结

    任何应用都离不开数据,所以在学习python的时候,当然也要学习一个如何用python操作数据库了.MySQLdb就是python对mysql数据库操作的模块.官方Introduction : MyS ...

  8. Linux Shell系列教程之(九)Shell判断 if else 用法

    本文是Linux Shell系列教程的第(九)篇,更多shell教程请看:Linux Shell系列教程 判断语句是每个语言都必不可少的关键语法,Shell命令当然也不例外.今天就给大家介绍下Shel ...

  9. 【bzoj3751】[NOIP2014]解方程 数论

    题目描述 已知多项式方程: a0+a1*x+a2*x^2+...+an*x^n=0 求这个方程在[1,m]内的整数解(n和m均为正整数). 输入 第一行包含2个整数n.m,每两个整数之间用一个空格隔开 ...

  10. [USACO Section 2.1]城堡 The Castle (搜索)

    题目链接 Solution 比较恶心的搜索,思路很简单,直接广搜找联通块即可. 但是细节很多,要注意的地方很多.所以直接看代码吧... Code #include<bits/stdc++.h&g ...