数组排序
首先拿到一个数组,然后这个是按照数字中Item元素的 name 属性来排序的代码片段:
searchResults.sortInPlace({ result1,result2 in
return result1.name.localizedStandardCompare(result2.name) == .OrderedAscending
})
这个使用的方法是sortInPlace
,还有另外一个方法是sort
。
如果使用了sort
,那么原来的数组是不会有任何变化的,使用sortInPlace
,会在原来的数组上做修改。
还可以简化为:
searchResults.sortInPlace{
$0.name.localizedStandardCompare($1.name) == .OrderedAscending
}
第二种写法没有传统的括号 (),使用 $0 来标记两个 $1 数组中的对象可读性很好,这是 Swift 的闭包(Closures)中很好的一个特性。
运算符重载
另外,可以使用运算符重载(operator overloading)
把这个做的更好:
在被排序对象的数组对象之外,记住是在Class之外,声明重载算术运算符的方法:
func < (lhs: SearchResult,rhs: SearchResult) -> Bool {
return lhs.name.localizedStandardCompare(rhs.name) == .OrderedAscending
}
有了这个方法,刚刚的排序就可以写的更短:
searchResults.sortInPlace{$0 < $1}
再短:
searchResults.sortInPlace(<)
End.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。