最近在看公司代码中发现了一个不常见的方法:
NSIndexSet *indexSet = [NSIndexSet indexSetWithIndexesInRange:NSMakeRange(0, statusCellArraM.count)];
查阅官方文档没有看到具体解释,只看到有个NSIndexSet
继承自NSObject;除了这些就没有其他解释了。于是乎只有自己去网上找资料
1.首先我们来看看NSIndexSet是个什么东西?
NSIndexSet是个无符号整数集合。集合中的元素不可变的、不可重复。常被用来当作索引使用。就从它字面上理解,就叫做:索引集合。
2.NSIndexSet的一些常用方法。
类方法:
创建一个空的索引集合。
+(id)indexSet;
创建一个索引集合,根据索引值
+(id)indexSetWithIndex:(NSUInteger)index;
创建一个索引集合,根据一个NSRange对象
+(id)indexSetWithIndexesInRange:(NSRange)indexRange;
3.实例方法:
判断索引集合中是否包含制定的索引值
-(BOOL)containsIndex:(NSUInteger)index;
判断索引集合是否包含指定的indexSet
-(BOOL)containsIndexes:(NSIndexSet *)indexSet;
判断索引集合是否包含指定的indexRange
-(BOOL)containsIndexesInRange:(NSRange)indexRange;
返回索引集合包含的索引数量
- (NSUInteger)count
返回indexRange中包含的索引数量
-(NSUInteger)countOfIndexesInRange:(NSRange)indexRange
枚举NSIndexSet;执行Block操作,在指定的Rang范围内,并使用指定的options方法。
-(void)enumerateIndexesInRange:(NSRange)rangeoptions:(NSEnumerationOptions)optsusingBlock:(void (^)(NSUInteger idx, BOOL *stop))block
如果,要枚举的NSIndexSet中不存在Rang中所指定的范围,则跳过。
options参数:
enum {
NSEnumerationConcurrent= (1UL<< 0),
NSEnumerationReverse= (1UL <<1),
};
typedefNSUIntegerNSEnumerationOptions;
NSEnumerationConcurrent
枚举过程中,各个Block是同时开始执行的。这样枚举的完成顺序是不确定的。
NSEnumerationReverse
以反序方式枚举。
4.例子 // theTwo中是否包含theOne
BOOLisContains1= [theTwocontainsIndexes:theOne];
BOOLisContains2= [theTwocontainsIndex:1];
BOOLisContains3= [theTwocontainsIndex:9];
// theTwo中是否包含指定的NSMakeRange
BOOLisContains4= [theTwocontainsIndexesInRange:NSMakeRange(0,5)];
inttheCount=[theTwocount];
//遍历theTwo,在指定的Range范围内,执行Block方法,利用制定的options方式
//如果,theTwo中不存在Range中所指定的范围,在theTwo中不存在,则跳过。
[theTwoenumerateIndexesInRange:NSMakeRange(0,8)
options:NSEnumerationReverse
usingBlock:^(NSUIntegeridx,BOOL*stop) {
NSLog(@"-------%d",idx);
NSLog(@"%@",theTwo);
}];
其他的方法,都差不多,就不一一介绍了。