1、集合遍历

 1> 遍历

  集合(Collection):OC中提供的容器类:数组,字典,集合。

  遍历:对集合中元素依次取出的过称叫做遍历。

  三种方式:① for循环遍历; ② NSEnumerator遍历; ③ for...in遍历

 2> for循环遍历

  ① 数组遍历

   原理:通过for循环的循环变量用作数组元素下标来获取不同下标的元素。

   循环次数就是数组元素的个数。

 // 数组
for (int i = ; i < arr.count; i++) {
NSLog(@"%@", arr[i]);
}

  ② 字典遍历

   原理:先获取字典中所有的key,存储到数组中,遍历数组依次取出每一个key,然后根据key从字典中取出对应的value

   循环次数就是字典元素的个数。

         // 字典
// 获取字典中所有的key值
NSArray *allKey = [dict allKeys];
// 遍历key值数组,访问对应的object值
for (int i = ; i < allKey.count; i++) {
NSString *key = allKey[i];
NSLog(@"%@", [dict objectForKey:key]);
}

  ③ 集合遍历

   原理:用集合的allObjects属性先取到集合的所有元素存储到数组中,再通过for循环的循环变量用作下标来取到每个元素。

         // 集合
// 取出集合中的所有元素放到数组中
NSArray *setArray = [set allObjects];
for (int i = ; i < setArray.count; i++) {
NSLog(@"%@", setArray[i]);
}

 3> NSEnumerator

  ① 概述

   枚举器,遍历集合中的元素。

   依附于集合类(NSArray,NSSet,NSDictionary),没有用来创建实例的接口。

   NSEnumerator的 nextObject 方法可以遍历每个集合元素,结束返回 nil ,通过与 while 结合使用可遍历集合中所有元素。

   对可变集合(数组,字典,集合)进行枚举操作时,不能通过添加或删除对象这类方式来改变集合容器的元素个数。

  ② 数组遍历

   正序(objectEnumerator)

         // 数组(正序)
// 创建正序的枚举器对象
NSEnumerator *arrayEnum1 = [arr objectEnumerator];
id value1 = nil;
// 判断value部位空打印数据
while ((value1 = [arrayEnum1 nextObject])) {
NSLog(@"%@", value1);
}    

   倒序(reverseObjectEnumerator)

         // 数组(倒序)
// 创建倒序的枚举器对象
NSEnumerator *arrayEnum2 = [arr reverseObjectEnumerator];
id value2 = nil;
while ((value2 = [arrayEnum2 nextObject])) {
NSLog(@"%@", value2);
}

  注:枚举器的nextObject方法只能取出一个对象,所以需要和while循环结合把所有元素依次取出。

  ③ 字典遍历

         // 字典
// 遍历到的是字典中的value值
NSEnumerator *dictEnum = [dict objectEnumerator];
id value3 = nil;
while ((value3 = [dictEnum nextObject])) {
NSLog(@"%@", value3);
}

  注:字典中存放的数据是无序的,没有反向枚举的概念。

  ④ 集合遍历

         // 集合
NSEnumerator *setEnum = [set objectEnumerator];
id value4 = nil;
while ((value4 = [setEnum nextObject])) {
NSLog(@"%@", value4);
}

  注:集合中存放的数据是无序的,没有反向枚举的概念。

 4> for...in 遍历

  ① 概述

   for...in:快速枚举,是在NSEnumerator的基础上封装的更加方便的快速的遍历集合元素的方式。

   格式:for (集合中对象的类型 * 元素名 in 被遍历的集合) {

      语句;

       }

   对可变集合(数组,字典,集合)进行快速枚举操作时,不能通过添加或删除对象这类方式来改变集合容器的元素个数。

  ② 数组遍历

         // 数组
for (id value in arr) {
NSLog(@"%@", value);
}

  ③ 字典遍历

         // 字典 遍历的是字典的key
for (id value in dict) {
NSLog(@"%@", dict[value]);
}

  ④ 集合遍历

         // 集合
for (id value in set) {
NSLog(@"%@", value);
}

2、数组排序

 数组是有序容器,因此集合中只有数组才能排序。

 1> NSSortDescriptor(排序描述符)概述

  该类能够方便的实现对数组中的对象进行升序或者降序的排序。

  它可以把元素的某个属性作为key进行升序或降序的排序,每个NSSortDescriptor对象就是一个排序条件。

 2> NSSortDescriptor创建方法

  初始化方法

  - (instancetype)initWithKey:(NSString *)key ascending:(BOOL)ascending;

  key:按照数组中对象的哪个属性进行排序,如果数组中存放的是能够直接排序的对象(比如:字符串),直接使 @"self" 或者 nil 即可;如果存放的是自定义类的对象,使用想要进行排序的属性名即可(比如:想按照Person类的name进行排序, 使用 @"name" 作为参数)。
       ascending:排序的标志,是升序还是降序。 YES - 升序, NO - 降序。

NSSortDescriptor创建

1 NSSortDescriptor *sortDes1 = [[NSSortDescriptor alloc] initWithKey:@"self" ascending:YES]; // 升序
2 NSSortDescriptor *sortDes2 = [[NSSortDescriptor alloc] initWithKey:@"name" ascending:NO]; // 降序

  ① 不可变数组

排序

 // 基本数据类型不可变数组
array = [array sortedArrayUsingDescriptors:@[sortDes1]];
NSLog(@"%@", array);
// 自定义对象不可变数组
// 按照名字排序
personArray = [personArray sortedArrayUsingDescriptors:@[sortDes2]];
NSLog(@"%@", personArray);

 ② 可变数组

排序

 // 基本类型可变数组
[mArray sortUsingDescriptors:@[sortDes1]];
NSLog(@"%@", mArray);
// 自定义对象可变数组
// 按照名字排序
[personMArray sortUsingDescriptors:@[sortDes2]];
NSLog(@"%@", personMArray);

 3> 使用数组中 两个元素比较的方法名 进行排序

  ① 不可变数组排序:(排序结果生成新数组, 原数组无改变)

   - (NSArray *)sortedArrayUsingSelector:(SEL)comparator;

   注:SEL类型的参数comparator:需要传入一个返回结果是NSComparisonResult的方法名。

 // 不可变数组(基本数据类型)
array = [array sortedArrayUsingSelector:@selector(compare:)];
NSLog(@"%@", array);
// 不可变的数组(自定义类型的对象)
// 按照名字排序
personArray = [personArray sortedArrayUsingSelector:@selector(compareByName:)]; // compareByName为Person类中自定义的方法
NSLog(@"%@", personArray);

  ② 可变数组排序:(直接对原数组操作,无新数组生成)

   - (void)sortUsingSelector:(SEL)comparator;

   注:SEL类型的参数comparator:需要传入一个返回结果是NSComparisionResult的函数

 // 可变数组(基本数据类型)
[mArray sortUsingSelector:@selector(compare:)];
NSLog(@"%@", mArray);
// 可变的数组(自定义类型的对象)
// 按照名字排序
[personMArray sortUsingSelector:@selector(compareByName:)];
NSLog(@"%@", personMArray);

  Person类中compareByName方法:

          // 比较方法的声明
- (NSComparisonResult)compareByName:(Person *)anotherPerson;
// 比较方法的实现
- (NSComparisonResult)compareByName:(Person *)anotherPerson {
return [self.name compare:anotherPerson.name];
}

iOS学习16之OC集合遍历和数组排序的更多相关文章

  1. iOS学习之Object-C语言集合遍历和数组排序

    一.集合遍历      1.集合:OC中提供的容器类,数组,字典,集合.      2.遍历:对集合中元素依次取出的过程叫做遍历. 二.for循环遍历      1.通过for循环的循环变量用作数组元 ...

  2. iOS学习15之OC集合

    1.数组类 1> 回顾C语言数组 数组是一个有序的集合, 来存储相同数据类型的元素. 通过下标访问数组中的元素,下标从 0 开始. 2> 数组 数组是一个有序的集合,OC中的数组只能存储对 ...

  3. IOS学习之路--OC的基础知识

    1.项目经验 2.基础问题 3.指南认识 4.解决思路 ios开发三大块: 1.Oc基础 2.CocoaTouch框架 3.Xcode使用 -------------------- CocoaTouc ...

  4. 【IOS学习基础】OC类的相关

    几天前突然在别人的类的.m文件中看到这么一句代码:@synthesize xxxx = _xxxx; 当时愣是没理解啥意思,过后才缓过神来发现原来是把一些类的基础知识忘记了,虽然不用过多去深究以前的一 ...

  5. iOS学习17之OC内存管理

    1.内存管理的方式 1> iOS应用程序出现Crash(闪退),90%的原因是因为内存问题. 2> 内存问题 野指针异常:访问没有所有权的内存,如果想要安全的访问,必须确保空间还在 内存泄 ...

  6. iOS学习14之OC NSNumber + NSValue

    1.NSNumber 数值类. 作用:实现基本数据类型与OC对象类型的相互转化. 1> NSNumber创建对象 // 初始化方法 NSNumber *num1 = [[NSNumber all ...

  7. iOS学习10之OC类和对象

    本次是OC的第一节课,主要是学习和理解类与对象 1.面向对象 1> OOP(Object Oriented Programming)面向对象编程. 面向对象以事物为中心,完成某件事情都需要哪些事 ...

  8. iOS学习之Object-C语言集合

    一.数组类      1.C语言数组的特点:数组是一个有序的集合,用来存储相同数据类型的元素,通过下标访问数组中的元素,下标从0开始.      2.OC中的数组只能存储对象类型(必须是NSObjec ...

  9. 【原】iOS学习18之OC内存管理高级

    1.属性的内存管理 1> 属性的语义特性 2> assign下的属性内部实现 @property (nonatomic, assign) NSString *name; @synthesi ...

随机推荐

  1. Git 操作的一些场景

    1. 某些不需要的文件/文件夹,如:/build 之类,在添加对应的gitignore之前Push了,导致每次编译都会产生新的文件 解决方法:直接删掉不需要的文件/文件夹,然后push gitigno ...

  2. codevs 2851 菜菜买气球

    dp加二分法 链接:http://codevs.cn/problem/2851/ #include<iostream> #include<vector> #include< ...

  3. Android -- java.lang.NoClassDefFoundError: Class not found using the boot class loader; no stack trace available

    使用Bundle 的getParcelableArray 出现了以下错误: Class not found when unmarshallingjava.lang.ClassNotFoundExcep ...

  4. Faster-rnnlm代码分析2 - HSTree的构造

    也就是构造一棵Huffman Tree,输入是按照词汇频次由高到低排序的 采用层次SoftMax的做法,是为了使得训练和预测时候的softmax输出加速,原有multinomal softmax,是和 ...

  5. Filp Game

    Flip Game Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 25573   Accepted: 11052 题目链接: ...

  6. SQL分组和聚合(Grouping and Aggregates)

    这章应该是难点,也是成为SQL高手的必经之路. 注意有GROUP 语句时,WHERE和HAVING的场合. 前者用于检索前的条件过滤 . 后者用于检索出来结果之后的条件过滤. ========== ; ...

  7. lucene/solr 修改评分规则方法总结

    说明:由于solr底层使用的是lucene,因此修改solr打分机制归根结底还是依赖于lucene的打分机制,本文主要讨论lucene的打分机制. 本文说明lucene 常用的四种影响评分结果的方式. ...

  8. 团队作业-第一周-NABCD竞争性需求分析

      1.  Need 需求 随着科技信息的发展,传统的课堂点名亟待步入信息处理的轨道,移动校园课堂点名软件恰好的切入了这个需求点,市场中词类软件也为数不多,因此需求也是比较强烈. 2. Approac ...

  9. 利用Browser Link提高前端开发的生产力

    (此文章同时发表在本人微信公众号"dotNET每日精华文章",欢迎右边二维码来关注.) 题记:Browser Link是VS 2013开始引入的一个强大功能,让前端代码(比如Ang ...

  10. 【c++】必须在类初始化列表中初始化的几种情况

    转自:http://www.cnblogs.com/kaituorensheng/p/3477630.html 1. 类成员为const类型 2. 类成员为引用类型 #include <iost ...