Swift资源包--Sort方法

来源:互联网 发布:如何删除网络驱动器 编辑:程序博客网 时间:2024/06/06 01:40
1,使用sort方法和闭包进行数组排序
sort方法返回一个数组的有序版本。(sort方法即为Swift2.0之前的sorted方法。而原来的sort方法改名为sortInPlace,用来将原数组修改成有序版本)
let numbers = [12,25,1,35,27]
 
let numbersSorted = numbers.sort({ (n1:Int, n2:Int) -> Boolin
    //进行从小到大的排序
    returnn2 > n1
})
 
print(numbersSorted)//[1, 12, 25, 27, 35]

2,闭包可以不用指定参数类型,编译器会帮我们推断的
let numbers = [12,25,1,35,27]
 
letnumbersSorted = numbers.sort({ n1, n2in
    //进行从小到大的排序
    returnn2 > n1
})
 
print(numbersSorted)//[1, 12, 25, 27, 35]

3,还可以省略参数名,直接根据数字来引用每个参数($0,$1,$2......)
let numbers = [12,25,1,35,27]
 
letnumbersSorted = numbers.sort({
    //进行从小到大的排序
    return$1 > $0
})
 
print(numbersSorted)//[1, 12, 25, 27, 35]

4,如果闭包只包含一行代码,可以省略return关键字
let numbers = [12,25,1,35,27]
 
let numbersSorted = numbers.sort({
    //进行从小到大的排序
    $1 > $0
})
 
print(numbersSorted)//[1, 12, 25, 27, 35]

5,如果一个闭包是函数调用的最后一个参数,可以将它放在括号外面。提高可读性。
let numbers = [12,25,1,35,27]
 
letnumbersSorted = numbers.sort(){
    //进行从小到大的排序
    $1 > $0
}
print(numbersSorted)//[1, 12, 25, 27, 35]

6,这个换行也是可选的,所以代码可再次精简
let numbersSorted = numbers.sort(){ $1 > $0 }

7,闭包也可以存储在变量中,像调用函数一样调用它们
let comparator = {(a: Int, b:Int)ina < b}
comparator(2,5) //true
最后感谢://http://www.hangge.com/blog/cache/detail_809.html
0 0
原创粉丝点击