Com o Swift 5, Array
tem dois métodos chamados sorted()
e sorted(by:)
. O primeiro método,, sorted()
tem a seguinte declaração:
Retorna os elementos da coleção, classificados.
func sorted() -> [Element]
O segundo método,, sorted(by:)
tem a seguinte declaração:
Retorna os elementos da coleção, classificados usando o predicado fornecido como a comparação entre os elementos.
func sorted(by areInIncreasingOrder: (Element, Element) throws -> Bool) rethrows -> [Element]
# 1 Classificar em ordem crescente para objetos comparáveis
Se o tipo de elemento dentro de sua coleção Comparable
estiver em conformidade com o protocolo, você poderá usá-lo sorted()
para classificar seus elementos em ordem crescente. O seguinte código do Playground mostra como usar sorted()
:
class ImageFile: CustomStringConvertible, Comparable {
let fileName: String
let fileID: Int
var description: String { return "ImageFile with ID: \(fileID)" }
init(fileName: String, fileID: Int) {
self.fileName = fileName
self.fileID = fileID
}
static func ==(lhs: ImageFile, rhs: ImageFile) -> Bool {
return lhs.fileID == rhs.fileID
}
static func <(lhs: ImageFile, rhs: ImageFile) -> Bool {
return lhs.fileID < rhs.fileID
}
}
let images = [
ImageFile(fileName: "Car", fileID: 300),
ImageFile(fileName: "Boat", fileID: 100),
ImageFile(fileName: "Plane", fileID: 200)
]
let sortedImages = images.sorted()
print(sortedImages)
/*
prints: [ImageFile with ID: 100, ImageFile with ID: 200, ImageFile with ID: 300]
*/
# 2 Classificar em ordem decrescente para objetos comparáveis
Se o tipo de elemento dentro de sua coleção Comparable
estiver em conformidade com o protocolo, você precisará usar sorted(by:)
para classificar seus elementos com uma ordem decrescente.
class ImageFile: CustomStringConvertible, Comparable {
let fileName: String
let fileID: Int
var description: String { return "ImageFile with ID: \(fileID)" }
init(fileName: String, fileID: Int) {
self.fileName = fileName
self.fileID = fileID
}
static func ==(lhs: ImageFile, rhs: ImageFile) -> Bool {
return lhs.fileID == rhs.fileID
}
static func <(lhs: ImageFile, rhs: ImageFile) -> Bool {
return lhs.fileID < rhs.fileID
}
}
let images = [
ImageFile(fileName: "Car", fileID: 300),
ImageFile(fileName: "Boat", fileID: 100),
ImageFile(fileName: "Plane", fileID: 200)
]
let sortedImages = images.sorted(by: { (img0: ImageFile, img1: ImageFile) -> Bool in
return img0 > img1
})
//let sortedImages = images.sorted(by: >) // also works
//let sortedImages = images.sorted { $0 > $1 } // also works
print(sortedImages)
/*
prints: [ImageFile with ID: 300, ImageFile with ID: 200, ImageFile with ID: 100]
*/
# 3 Classificar em ordem crescente ou decrescente para objetos não comparáveis
Se o tipo de elemento dentro de sua coleção NÃO Comparable
estiver em conformidade com o protocolo, você precisará usar sorted(by:)
para classificar seus elementos em ordem crescente ou decrescente.
class ImageFile: CustomStringConvertible {
let fileName: String
let fileID: Int
var description: String { return "ImageFile with ID: \(fileID)" }
init(fileName: String, fileID: Int) {
self.fileName = fileName
self.fileID = fileID
}
}
let images = [
ImageFile(fileName: "Car", fileID: 300),
ImageFile(fileName: "Boat", fileID: 100),
ImageFile(fileName: "Plane", fileID: 200)
]
let sortedImages = images.sorted(by: { (img0: ImageFile, img1: ImageFile) -> Bool in
return img0.fileID < img1.fileID
})
//let sortedImages = images.sorted { $0.fileID < $1.fileID } // also works
print(sortedImages)
/*
prints: [ImageFile with ID: 300, ImageFile with ID: 200, ImageFile with ID: 100]
*/
Observe que o Swift também fornece dois métodos chamados sort()
e sort(by:)
como equivalentes sorted()
e sorted(by:)
se você precisar classificar sua coleção no local.