第一种方式:for-in循环

OC延续了C语言的for循环,在Swift中被彻底改造,我们无法再使用传统形式的for循环了

遍历数组和字典:

  //遍历数组
let iosArray = ["L", "O", "V", "E", "I", "O", "S"] for index in ... {
print(iosArray[index])
} for index in ..< {
print(iosArray[index])
} for element in iosArray {
print(element)
} //遍历字典
let iosDict = ["": "one", "": "two", "": "three", "": "four"]
for (key, value) in iosDict {
print("\(key): \(value)")
} //单独遍历字典的key和value
let keys = iosDict.keys
for k in keys {
print(k)
} let values = iosDict.values
for v in values {
print(v)
}

如上遍历数组使用了2种方式

1、
第一种方式是Swift中普通的for循环语法,在索引index和遍历范围0...6之间用关键字in,这里要注意0...6的表示的范围是:0<= index <= 6,而0..<6表示的是:0<= index < 6,这里要注意的是没有:0<..6的形式。只要熟悉了Swift语法,以上这些并不难理解。
拓展1:0...6的形式还可以取出制定范围的数组中的元素,代码如下:

   let sectionArray = iosArray[...]
print(sectionArray)
输出:
▿ elements
- : "O"
- : "V"
- : "E"
- : "I"

拓展2:0...6的形式还可以用来初始化创建数组,代码如下:
  let numbers = Array(...)
print(numbers)
输出:
▿ elements
- :
- :
- :
- :
- :
- :
- :

也就是说以后遇到涉及范围的情况都可以尝试0...6这种形式,看看是否可以迅速获取指定范围内的元素,可用的地方还有很多,小伙伴自己掘金吧。

2、
第二种方式类似于OC中的快速遍历,不需要索引直接就可以访问到数组中的元素,也很好理解。


字典的遍历可分为同时或者分别遍历key和value

1、
同时遍历key和value时利用了Swift的元组,元组可以把不同类型的值组合成一个复合的值,使用起来非常方便,这样就可以同时拿到字典的key和value了。

2、
单独遍历字典的key个value时,需要注意的是,keys和values并不是Array,因此无法直接使用keys[0]的形式访问,他们实际的类型是LazyMapCollection<[Key : Value], Key>,显然不是一个数组。当然我们可以将他们转换成数组,如下:

     //将字典的kyes转换成数组   let keys = Array(iosDict.keys)  print(keys[]) 

由于字典是无序的,所有这么做的意义并不大。

第二种方式:Swift为for循环带来的惊喜

将以下内容单拿出来作为第二种方式不太合适,其实这部分还是属于Swift的for-in循环,单独拿出来是出于对这种方式的喜爱,也让大家在看的时候更加醒目。

反向遍历

     //倒序遍历数组
for index in (...).reversed() {
print(iosArray[index])
} for element in iosArray.reversed() {
print(element)
} //倒序遍历字典
for (key, value) in iosDict.reversed() {
print("\(key): \(value)")
}
1、如上无论是0...6这种索引方式还是快速遍历,都可直接调用reversed()函数轻松实现反向遍历。

2、
对于字典的反向遍历,有些小伙伴可能会有些疑问,字典是无序的,反向和正向遍历有区别吗,似乎意义不大。这里需要说明的是,字典的无序是说不保证顺序,但是在内存中是按照顺序排列的,只是这种顺序不一定按照我们存入或者编码的顺序排列,因此字典的反向遍历也是有意义的。

3、
看过我去年总结的OC循环遍历的小伙伴一定还记得,当我们需要在遍历集合时改变集合中的元素时,正向遍历会偶尔出现崩溃的问题,尤其是数据量较大时几乎每次都会崩溃,当我们使用反向遍历时就没有崩溃的问题了,在Swift中为了保证程序的稳定,也建议在遍历集合需要修改集合元素时采用反向遍历。

拓展:reversed()函数实际上是返回给我们一个顺序完全颠倒的集合,那么我们就可以利用这个函数得到一个倒序的集合,非常方便,代码如下:

    //获取倒序数组   let reversedArray = Array(iosArray.reversed())  print(reversedArray) 

forEach遍历

如果还有小伙伴认为for-in遍历繁琐,Swift还提供了一种更加简洁的遍历方式forEach,代码如下:

   //使用forEach正向遍历
iosArray.forEach { (word) in
print(word)
} //使用forEach的反向遍历
iosArray.reversed().forEach { (word) in
print(word)
}

注意: 1、不能使用“break”或者“continue”退出遍历; 2、使用“return”结束当前循环遍历,这种方式只是结束了当前闭包内的循环遍历,并不会跳过后续代码的调用。


stride遍历

  • stride遍历分为
  •  stride(from: <#T##Strideable#>, to: <#T##Strideable#>, by: <#T##Comparable & SignedNumeric#>)
  •  stride(from: <#T##Strideable#>, through: <#T##Strideable#>, by: <#T##Comparable & SignedNumeric#>)

两种遍历方式,代码如下:

  
   //stride正向遍历
for index in stride(from: , to: , by: ) {
print(index)
print(iosArray[index])
} //stride正向跳跃遍历
for index in stride(from: , to: , by: ) {
print(index)
print(iosArray[index])
} //stride反向遍历
for index in stride(from: , to: , by: -) {
print(index)
print(iosArray[index])
} //stride through正向遍历
for index in stride(from: , through: , by: ) {
print(index)
print(iosArray[index])
}
1、

正如stride单词的含义“大步跨过”,使用这种方式遍历的好处自然是可以灵活的根据自己的需求遍历,比如我们有时需要遍历索引为偶数或者基数的元素,或者每隔3个元素遍历一次等等类似的需求都可以轻松实现;

2、
stride遍历同样可以实现正向和反向的遍历,在by后面添加正数表示递增的正向遍历,添加负数表示递减的反向遍历;

3、
to和through两种遍历方式的不同在于to不包含后面的索引,而through包含后面的索引,以to: 6through: 6为例,to:<6或者>6through:<=6或者>=6,至于是<还是>取决于是正向遍历还是反向遍历。

第三种方式:基于块的遍历

OC拥有一套很优雅基于快的遍历,Swift保持了这套优秀的接口,下面来看看Swift是如何使用的。

正向遍历

     //遍历数组
for (n, c) in iosArray.enumerated() {
print("\(n): \(c)")
} //遍历字典
for (n, c) in iosDict.enumerated() {
print("\(n): \(c)")
}

注意: 1、(n, c)中n表示元素的输入顺序,c表示集合中的每一个元素; 2、由于数组是有序的,所以在数组中n自然也可以表示每一个元素在数组中索引,而字典是无序的,但是n依然会按照0、1、2...的顺序输入,因此不可以代表在字典中的索引。


反向遍历

  //反向遍历数组
for (n, c) in iosArray.enumerated().reversed() {
print("\(n): \(c)")
} //反向遍历字典
for (n, c) in iosDict.enumerated().reversed() {
print("\(n): \(c)")
}

反向遍历就是直接在enumerated()函数后调用reversed()函数。

Swift循环遍历集合方法的更多相关文章

  1. Map<String, String>循环遍历的方法

    Map<String, String>循环遍历的方法 Map<String, String>循环遍历的方法 Map<String, String>循环遍历的方法 下 ...

  2. for循环和foreach循环遍历集合的效率比较

    先上代码 package com.test; import java.util.ArrayList; import java.util.LinkedList; import java.util.Lis ...

  3. 增强for循环遍历集合或数组

    遍历:for循环遍历数组或集合:iterator迭代器遍历集合:还有增强for循环(for each)遍历数组或集合: 遍历数组: 遍历集合:

  4. 使用增强for循环遍历集合的时候操作集合的问题?

    // 遍历一个list public static void printList(List<String> list){ for (String string : list) { list ...

  5. jquery中object对象循环遍历的方法

    一个朋友问对象如何转为数组,当我问他为啥要转得时候,他告诉我,数组可以用js循环遍历,而对象则不可以.其实呢,对象同样可以循环遍历的啊.不用转换也可以循环!说明你对js或者jquery的某些操作不是很 ...

  6. 集合-新特性foreach循环遍历集合或项目

    1.增强for循环对集合的遍历 点击查看代码 @Test //集合遍历 public void test3(){ Collection coll = new ArrayList(); coll.add ...

  7. linux shell 中数组的定义和for循环遍历的方法

    linux 中定义一个数据的语法为: variable=(arg1 arg2 arg3 ....) 中间用空格分开.数组的下标从0开始. 1 获取下标为n的元素: variable[n] 而且不存在数 ...

  8. [Swift]遍历集合类型(数组、集合和字典)

    Swift提供了三种主要的集合类型,称为数组,集合和字典,用于存储值集合. 数组是有序的值集合. 集是唯一值的无序集合. 字典是键值关联的无序集合. Swift中无法再使用传统形式的for循环. // ...

  9. java基础29 迭代器 listIterator() 及各种遍历集合的方法

    listIterator() 迭代器包含了 Iterator() 迭代器中的所有方法. 1.ListIterator的常用方法 hasPrevious() :判断是否还有上一个元素,有则返回true  ...

随机推荐

  1. 2018.09.23 atcoder Boxes and Candies(贪心)

    传送门 一道挺有意思的贪心. 从1到n依次满足条件. 注意要特判第一个数已经大于x的情况. 但是如何贪心吃呢? 如果靠左的数没有越界,我们吃靠右的数. 原因是下一次靠右的数就会成为靠左的数,相当于多贡 ...

  2. 2018.07.20 bzoj1614: Telephone Lines架设电话线(二分+最短路)

    传送门 这题直接做显然gg" role="presentation" style="position: relative;">gggg,看这数据 ...

  3. 【转】ORACLE 表空间扩展方法

    转载地址:http://blog.itpub.net/28950170/viewspace-763139/ 第一步:查看表空间的名字及文件所在位置: select tablespace_name, f ...

  4. IntelliJ IDEA 2017版 spring-boot使用Spring Data JPA搭建基础版的三层架构

    1.配置环境pom <?xml version="1.0" encoding="UTF-8"?> <project xmlns="h ...

  5. 转:解决windows下eclipse中android项目关联android library project失败问题

    近日,在做一个人人的第三方小项目.打算直接使用renren 的sdk 进行开发.因为renren的sdk是以android library project 形式发布的(关于这种project的内容可以 ...

  6. 如何利用Visio设计一个系统的结构图

    首先建立一个空的vison列表 添加图形和连接线 托选一个矩形块到操作台上,并进行底色填充 选择有向线段1拖到矩形模块上,此时有向线段1会自动吸附到矩形的中点处. 此时按下图操作即可取消,自动吸附 托 ...

  7. hdu 1116 欧拉回路+并查集

    http://acm.hdu.edu.cn/showproblem.php?pid=1116 给你一些英文单词,判断所有单词能不能连成一串,类似成语接龙的意思.但是如果有多个重复的单词时,也必须满足这 ...

  8. hdu 4994 前后有序Nim游戏

    http://acm.hdu.edu.cn/showproblem.php?pid=4994 Nim游戏变成从前往后有序的,谁是winner? 如果当前堆数目为1,玩家没有选择,只能取走.遇到到不为1 ...

  9. How To Change the Supplier Bank Account Masking in UI (Doc ID 877074.1)

      Give Feedback...           How To Change the Supplier Bank Account Masking in UI (Doc ID 877074.1) ...

  10. 拷贝构造函数——防篡改

    对于普通类型的对象来说,他们之间的复制是简单的,比如: int a = 88; int b = a; 而类和普通对象不同,类对象内部结构一般较为复杂,存在各种成员变量. #include <io ...