Swift资源包--Sort方法

1,使用sort方法和闭包进行数组排序
sort方法返回一个数组的有序版本。(sort方法即为Swift2.0之前的sorted方法。而原来的sort方法改名为sortInPlace,用来将原数组修改成有序版本)
let numbers = [12,25,1,35,27]
 
let numbersSorted = numbers. sort ({ (n1: Int , n2: Int ) -> Bool in
     //进行从小到大的排序
     return n2 > n1
})
 
print (numbersSorted) //[1, 12, 25, 27, 35]

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

3,还可以省略参数名,直接根据数字来引用每个参数($0,$1,$2......)
let numbers = [12,25,1,35,27]
 
let numbersSorted = 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]
 
let numbersSorted = 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 ) in a < b}
comparator(2,5) //true
最后感谢://http://www.hangge.com/blog/cache/detail_809.html

你可能感兴趣的:(排序方法,sort方法,swift_闭包,swift_sort,swift_函数_方法)