摘要:实现一个内部迭代器可以看出内部迭代器在调用的时候非常简单使用者不用关心迭代器内部实现的细节但这也是内部迭代器的缺点。两数组不等外部迭代器将遍历的权利转移到外部两数组相等两数组相等
实现一个内部迭代器
function each(arr,fn){ for(let i =0; i可以看出内部迭代器在调用的时候非常简单, 使用者不用关心迭代器内部实现的细节, 但这也是内部迭代器的缺点。比如要比较两数组是否相等, 只能在其回调函数中作文章了, 代码如下:
function each(arr, fn) { for (let i = 0; i < arr.length; i++) { fn(i, arr[i]) } } const compare = function (arr1, arr2) { var isTrue = 1 each(arr1, function (i, n) { if (arr2[i] !== n) { console.log("两数组不相等") isTrue = 2 return } }) if (isTrue == 1) { console.log("两数组相等") } } const arr1 = [1, 2, 3] const arr2 = [1, 2, 4] compare(arr1, arr2)//两数组不相等实现一个外部迭代器相较于内部迭代器, 外部迭代器将遍历的权利转移到外部, 因此在调用的时候拥有了更多的自由性, 不过缺点是调用方式较复杂。
const iterator = function(arr){ let current = 0 const next = function(){ current = current + 1 } const done = function(){ return current >= arr.length } const value = function(){ return arr[current] } return { next, done, value } } const arr1 = [1,2,3] const arr2 = [1,2,3] const iterator1 = iterator(arr1) const iterator2 = iterator(arr2) const compare = function(iterator1,iterator2){ while(!iterator1.done()&&!iterator2.done()){ if(iterator1.value() !== iterator2.value()){ console.log("两数组不等") return } iterator1.next() //外部迭代器将遍历的权利转移到外部 iterator2.next() } console.log("两数组相等") } compare(iterator1,iterator2) //两数组相等
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/106616.html
摘要:抓住了迭代器模式的本质,即是迭代,赋予了它极高的地位。输出结果输出结果小结迭代器模式几乎是种设计模式中最常用的设计模式,本文主要介绍了是如何运用迭代器模式,并介绍了模块生成迭代器的种方法,以及种生成迭代器的内置方法。 showImg(https://segmentfault.com/img/bVbmv7W?w=4272&h=2848); 在软件开发领域中,人们经常会用到这一个概念——设...
摘要:抓住了迭代器模式的本质,即是迭代,赋予了它极高的地位。输出结果输出结果小结迭代器模式几乎是种设计模式中最常用的设计模式,本文主要介绍了是如何运用迭代器模式,并介绍了模块生成迭代器的种方法,以及种生成迭代器的内置方法。 showImg(https://segmentfault.com/img/bVbmv7W?w=4272&h=2848); 在软件开发领域中,人们经常会用到这一个概念——设...
摘要:迭代器模式原文地址更多设计模式系列教程更多免费教程博主按每天一个设计模式旨在初步领会设计模式的精髓,目前采用靠这吃饭和纯粹喜欢两种语言实现。迭代器模式常见和常用的有内部迭代器外部迭代器倒序迭代器等等。 迭代器模式·原文地址 更多《设计模式系列教程》 更多免费教程 博主按:《每天一个设计模式》旨在初步领会设计模式的精髓,目前采用javascript(靠这吃饭)和python(纯粹喜欢...
阅读 485·2021-10-09 09:44
阅读 2031·2021-09-02 15:41
阅读 3532·2019-08-30 15:53
阅读 1812·2019-08-30 15:44
阅读 1255·2019-08-30 13:10
阅读 1150·2019-08-30 11:25
阅读 1383·2019-08-30 10:51
阅读 3346·2019-08-30 10:49