當前位置: 首頁>>代碼示例 >>用法及示例精選 >>正文


Swift AsyncSequence prefix(while:)用法及代碼示例


用法一

實例方法

prefix(while:)

返回一個異步序列,包含滿足給定謂詞的基本序列的初始連續元素。

聲明

@preconcurrency func prefix(while predicate: @escaping (Self.Element) async -> Bool) rethrows -> AsyncPrefixWhileSequence<Self>

返回值

滿足 predicate 的初始連續元素的異步序列。

參數

predicate

一個閉包,它將元素作為參數並返回一個布爾值,指示該元素是否應包含在修改後的序列中。

詳述

當基本序列中的元素滿足您指定的條件時,使用prefix(while:) 生成值。當謂詞閉包返回 false 時,修改後的序列結束。

在此示例中,名為 Counter 的異步序列生成從 110Int 值。 prefix(while:) 方法會導致修改後的序列傳遞值,隻要它們不能被 23 整除。到達 6 後,序列結束:


let stream = Counter(howHigh: 10)
    .prefix { $0 % 2 != 0 || $0 % 3 != 0 }
for try await number in stream {
    print("\(number) ", terminator: " ")
}
// prints "1  2  3  4  5"

可用版本

iOS 13.0+, iPadOS 13.0+, macOS 10.15+, Mac Catalyst 13.0+, tvOS 13.0+, watchOS 6.0+

用法二

實例方法

prefix(while:)

返回一個異步序列,包含滿足給定 error-throwing 謂詞的基本序列的初始連續元素。

聲明

@preconcurrency func prefix(while predicate: @escaping (Self.Element) async throws -> Bool) rethrows -> AsyncThrowingPrefixWhileSequence<Self>

返回值

按順序包含滿足給定謂詞的基本序列元素的異步序列。如果謂詞拋出錯誤,則序列僅包含在錯誤之前產生的值。

參數

predicate

error-throwing 閉包將異步序列的元素作為其參數,並返回一個布爾值,指示是否在修改後的序列中包含該元素。

詳述

當基本序列中的元素滿足您指定的條件時,使用prefix(while:) 生成值。當謂詞閉包返回 false 或拋出錯誤時,修改後的序列結束。

在此示例中,名為 Counter 的異步序列生成從 110Int 值。 prefix(_:) 方法會導致修改後的序列傳遞小於 8 的值,但當它接收到可被 5 整除的值時會引發錯誤:


do {
    let stream = try Counter(howHigh: 10)
        .prefix {
            if $0 % 5 == 0 {
                throw MyError()
            }
            return $0 < 8
        }
    for try await number in stream {
        print("\(number) ", terminator: " ")
    }
} catch {
    print("Error: \(error)")
}
// Prints: 1  2  3  4  Error: MyError()

可用版本

iOS 13.0+, iPadOS 13.0+, macOS 10.15+, Mac Catalyst 13.0+, tvOS 13.0+, watchOS 6.0+

相關用法


注:本文由純淨天空篩選整理自apple.com大神的英文原創作品 AsyncSequence prefix(while:)。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。