所以我们有一系列的Ints:
var numbers: Int[] = [1,2,3,4,5,6,7]
我应用这样的变换:(7)
func transformNumber(number: Int) -> Int { let result = number * 3 return result}numbers = numbers.map(transformNumber)
等于:(7)
numbers = numbers.map({(number: Int) -> Int in let result = number * 3 return result; })
等于:(8)
numbers = numbers.map({number in number * 3})
等于:(8)
numbers = numbers.map({numbers = numbers.map() { * 3}* 3})
等于:(8)
正如您在下图中所看到的, *** 场侧栏中的迭代计数显示,在函数声明的最远抽象中,它具有8个计数.
题
为什么它显示为最后两个示例的8次迭代?
解决方法 它确实没有显示8次迭代.它显示在该行上执行了8件事.作为map函数的一部分有7次执行,而第8次执行则返回number变量.看起来这可能提供更有用的诊断.我强烈建议您通过https://bugreport.apple.com提供反馈.
总结以上是内存溢出为你收集整理的swift – 为什么将一个未命名的函数作为变换传递给数组在最远的抽象中在 *** 场中添加一个到迭代计数全部内容,希望文章能够帮你解决swift – 为什么将一个未命名的函数作为变换传递给数组在最远的抽象中在 *** 场中添加一个到迭代计数所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)