max(by:)
Returns the maximum element in the asynchronous sequence, using the given predicate as the comparison between elements.
- iOS
- 13.0+
- macOS
- 10.15+
- tvOS
- 13.0+
- watchOS
- 6.0+
@warn_unqualified_access func max(by areInIncreasingOrder: (Self.Element, Self.Element) async throws -> Bool) async rethrows -> Self.Element? Parameters
- areInIncreasingOrder
A predicate that returns
trueif its first argument should be ordered before its second argument; otherwise,false.
Returns
The sequence’s minimum element, according to areInIncreasingOrder. If the sequence has no elements, returns nil.
Use this method when the asynchronous sequence’s values don’t conform to Comparable, or when you want to apply a custom ordering to the sequence.
The predicate must be a strict weak ordering over the elements. That is, for any elements a, b, and c, the following conditions must hold:
areInIncreasingOrder(a, a)is alwaysfalse. (Irreflexivity)If
areInIncreasingOrder(a, b)andareInIncreasingOrder(b, c)are bothtrue, thenareInIncreasingOrder(a, c)is alsotrue. (Transitive comparability)Two elements are incomparable if neither is ordered before the other according to the predicate. If
aandbare incomparable, andbandcare incomparable, thenaandcare also incomparable. (Transitive incomparability)
The following example uses an enumeration of playing cards ranks, Rank, which ranges from ace (low) to king (high). An asynchronous sequence called RankCounter produces all elements of the array. The predicate provided to the max(by:) method sorts ranks based on their rawValue:
enum Rank: Int {
case ace = 1, two, three, four, five, six, seven, eight, nine, ten, jack, queen, king
}
let max = await RankCounter()
.max { $0.rawValue < $1.rawValue }
print(max ?? "none")
// Prints "king"