我在一个小游乐场买了这个测试代码:
let array = [7,3,4,9,2,12,5]let firstSorted = array.sorted(<)let secondSorted = sorted(array,<)let thirdSorted = array.sorted {// they should probably rename this placeholder to S...func sorted<C : SequenceType> (source: C,isOrderedBefore: (C.Generator.Element,C.Generator.Element) -> Bool) -> [C.Generator.Element]< }
右侧显示的输出显示firstSorted和secondSorted旁边的排序数组输出.然而,ThirdSorted旁边的输出只是说(15次).
为什么?如何在不添加单独的println命令来记录输出的情况下查看输出?
第三种形式有一个尾随闭包,其参数由它们的位置指定.
另外两个是一个更短的形式,只采用比较运算符,恰好匹配所需的闭包的签名.
另一个问题:(这次关于语言,而不是游乐场)为什么sorted(array,<)和array.sorted(<)形式都有效?第一个是带有2个参数的全局函数,第二个是Array类的方法.
解决方法 这是因为你传递给sorted的闭包是通过排序调用来进行13个元素的比较,因为它对数组进行排序,再加上对自身排序的调用.每当您编写的代码行在 *** 场中运行时,它会显示表达式的结果或计数.由于多次评估同一行,因此IDE无法显示所有内容,因此它只显示计数.如果你把它分成多行,你可以看到排序的结果,以及$0< 0的13次评估的结果. $1: 我想IDE可以采用最外层结果最有趣的方法,并显示,但这可能隐藏了多次调用闭包的信息. 至于第二个问题:排序的全局2参数版本更为通用.它排序任何类型的序列:
// results in [4,1,0]sorted(0..<5,>) // results in [(3,"bob"),(2,"fred")] because dictionary’s // SequenceType representation is unordered pairssorted([2:"fred",3:"bob"]) {func sorted<C : SequenceType where C.Generator.Element : Comparable> (source: C) -> [C.Generator.Element].1 < .1 }
所以你可以传入任何符合SequenceType的东西:
此外,由于全局函数可以基于约束输入进行重载,因此如果输入序列的元素是Comparable,则可能存在根本不需要比较器的重载版本:
总结以上是内存溢出为你收集整理的swift – 为什么有些表达式记录结果而其他表达式只显示迭代计数?全部内容,希望文章能够帮你解决swift – 为什么有些表达式记录结果而其他表达式只显示迭代计数?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)