Mit Swift 5 Array
hat zwei Methoden aufgerufen sorted()
und sorted(by:)
. Die erste Methode sorted()
hat die folgende Deklaration:
Gibt die Elemente der Sammlung sortiert zurück.
func sorted() -> [Element]
Die zweite Methode sorted(by:)
hat die folgende Deklaration:
Gibt die Elemente der Sammlung zurück, sortiert nach dem angegebenen Prädikat als Vergleich zwischen Elementen.
func sorted(by areInIncreasingOrder: (Element, Element) throws -> Bool) rethrows -> [Element]
# 1. Sortieren Sie in aufsteigender Reihenfolge nach vergleichbaren Objekten
Wenn der Elementtyp in Ihrer Sammlung dem Comparable
Protokoll entspricht , können Sie sorted()
Ihre Elemente in aufsteigender Reihenfolge sortieren. Der folgende Spielplatzcode zeigt die Verwendung 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. Sortieren Sie in absteigender Reihenfolge nach vergleichbaren Objekten
Wenn der Elementtyp in Ihrer Sammlung dem Comparable
Protokoll entspricht , müssen Sie ihn verwenden sorted(by:)
, um Ihre Elemente in absteigender Reihenfolge zu sortieren.
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. Für nicht vergleichbare Objekte in aufsteigender oder absteigender Reihenfolge sortieren
Wenn der Elementtyp in Ihrer Sammlung NICHT dem Comparable
Protokoll entspricht, müssen Sie ihn verwenden sorted(by:)
, um Ihre Elemente in aufsteigender oder absteigender Reihenfolge zu sortieren.
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]
*/
Beachten Sie, dass Swift auch zwei Methoden bereitstellt, die als sort()
und sort(by:)
als Gegenstücke zu sorted()
und sorted(by:)
wenn Sie Ihre Sammlung direkt sortieren müssen.