首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

【Kotlin】循环控制流 ( for 循环 | Iterator 遍历形式 | Iterator 遍历要求 | IntArray 源码解析 )

文章目录 一、For 循环 二、For 循环遍历 Iterator 对象 三、Iterator 遍历要求 四、IntArray 源码解析 一、For 循环 ---- For 循环有两种遍历形式 : 一种是...遍历提供了迭代器 ( Iterator ) 的对象 ; 另一种是 使用区间表达式进行遍历 ; 二、For 循环遍历 Iterator 对象 ---- 提供了 Iterator 迭代器的对象基本就是 集合...(i in array){ println(i) } } 执行结果 : 遍历集合 0 1 2 3 4 遍历数组 5 6 7 8 9 三、Iterator 遍历要求 ---- 使用...for(i in array) 对 array 对象进行遍历 , 有以下要求 : 被遍历的对象必须 定义了 iterator() 方法 , 返回 Iterator 迭代器类型 , 并且该方法必须 标记为...可以按照顺序遍历元素 ; */ public interface Iterator { /** * 返回迭代器的下一个值 * 注意此处的 next() 方法有

85200

ES6之Iterator遍历

遍历器(Iterator)是一种接口,为各种不同的数据结构提供统一的访问机制。任何数据结构只要部署 Iterator 接口,就可以完成遍历操作(即依次处理该数据结构的所有成员)。...一种数据结构只要部署了Iterator接口,我们就称之为可遍历的(iterable)。...ES6 规定,默认的 Iterator 接口部署在数据结构的Symbol.iterator属性,或者说,一个数据结构只要具有Symbol.iterator属性,就可以认为是“可遍历的”(iterable...Symbol.iterator属性本身是一个函数,就是当前数据结构默认的遍历器生成函数。执行这个函数,就会返回一个遍历器。...除此之外,其他数据结构(主要是对象)的 Iterator 接口,都需要自己在Symbol.iterator属性上面部署,这样才会被for...of循环遍历

50940
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    for 、foreach 、iterator 三种遍历方式的比较

    for、foreach循环、iterator迭代器都是我们常用的一种遍历方式,你可以用它来遍历任何东西:包括数组、集合等 for 惯用法: List list = new ArrayList..."ms"); 4ms 16ms 9ms 由以上得知,for()循环是最快的遍历方式,随后是iterator()迭代器,最后是foreach循环 remove操作三种遍历方式的影响 for循环的remove...= expectedModCount ,所以抛出异常 Iterator迭代器的remove 使用迭代器进行遍历还有很多需要注意的地方: 正确的遍历 List list = new ArrayList...错误的遍历 —— 使用Arrays.asList() List list = Arrays.asList("1","2","3"); Iterator it = list.iterator...也就是说,只要这段代码执行了,都会报错,抛出异常 后记: 上述文章主要介绍了 for循环、foreach 循环、iterator 迭代器遍历元素的速度大小的比较 还介绍了各自遍历过程中 对remove操作的影响

    1.9K30

    js中map遍历数组对象_js遍历数组

    forEach()和map()都是遍历数组的方法,用法类似,但是还是有很大区别: 相同点:       1.都是循环遍历数组中的每一项;       2.在遍历中执行匿名函数都可以接收三个参数,分别为...:遍历过程的每一项、遍历序号(索引值)、原数组;       3.执行的匿名函数中 的this都指向window。...不同点:       map():       根据遍历执行的匿名函数,对于原数组中的每个值产生一个对应的值,并返回一个新的数组,存在一个映射关系,并且不会改变原数组,不会对空数组进行检测。...arr.forEach(function(i,index,arr){ sum += i; console.log("sum的值为:",sum); }) //执行5次,最终结果 10 ** js...中 map 遍历数组 ** map 方法会迭代数组中的每一个元素,并根据回调函数来处理每一个元素,最后返回一个新数组。

    19.6K30

    js中对数组进行遍历都有哪些方法_js遍历json对象

    遍历有如下几种方式 数组方法 map forEach filter find findIndex every some reduce reduceRight 其他方法 for for in for...[“子项0”, “子项1”, “子项2”] console.log(filterResult); [“子项0”] 缺陷 可以使用return,但是不能使用break和continue find 核心 遍历数组...; console.log(reduceRightResult);//结果: 10 缺陷 可以使用return,但是不能使用break和continue 其他方法 for循环 核心 使用临时变量,并且遍历的是...; i < testArr.length; i++) {if(i === 1) {return; } console.log(testArr[i]); }//结果为什么也没有 for in循环 核心 遍历的是...return for(let i intestArr){if(i === 1) {return; } console.log(testArr[i]); }//结果为什么也没有 for of循环 核心 遍历的是

    7.9K20

    前端测试题:关于Iterator遍历器的说法,错误的是?

    考核内容:Iterator遍历器的原理 题发散度: ★★ 试题难度: ★ 解题思路: 遍历器(Iterator)为各种不同的数据结构提供统一的访问机制。...任何数据结构只要部署 Iterator 接口,就可以完成遍历操作(即依次处理该数据结构的所有成员)。...Iterator 的作用有三个:一是为各种数据结构,提供一个统一的、简便的访问接口;二是使得数据结构的成员能够按某种次序排列;三是 ES6 创造了一种新的遍历命令for...of循环,Iterator...Iterator遍历过程是这样的。 (1)创建一个指针对象,指向当前数据结构的起始位置。也就是说,遍历器对象本质上,就是一个指针对象。...其中,value属性是当前成员的值,done属性是一个布尔值,表示遍历是否结束。 当next( )返回对象的done属性为fasle,表示遍历未结束,done属性为true时,表示遍历结束。

    1.6K20

    js 实现层序遍历

    = [] // 初始化当前层级 let countNum = queue.length // 当前层级的节点数 while(countNum--){ // 遍历当前层级的节点数...push(node.val) // 推入每层的节点值 node.left && queue.push(node.left) // 将当前层级的节点的左右节点推入栈中,供下一层级遍历...node.right && queue.push(node.right)// 将当前层级的节点的左右节点推入栈中,供下一层级遍历 } count...++ // 层级+1 } return res }; 基本逻辑: 层序遍历使用的时广度优先遍历,使用队列存取,先进先出,与广度优先遍历不同的是,广度优先遍历返回一个一维数组,不分层级...,层序遍历分层级,返回多维数组,在每次遍历的过程中,把整层节点都处理完之后,再处理下一层 1.

    3.1K20
    领券