文書   >   Swift   >   Swift 標準ライブラリ   >   Collections   >   Sequence and Collection Protocols   >   Collection   >   firstIndex(where:)
インスタンスメソッド
firstIndex(where:)
コレクションの要素が与えられた predicate (述語) を満たす最初のインデックスを返します。
宣言
func firstIndex(where predicate: (Self.Element) throws -> Bool) rethrows -> Self.Index?
パラメータ
predicate | 要素をその引数として受け取り、渡された要素が一致を表すかどうかを示すブール値を返すクロージャ。 |
戻り値
predicate (述語) が true を返す最初の要素のインデックス。コレクション内の要素が全て与えられた predicate (述語) を満たさない場合は、nil を返します。
議論
predicate (述語) を使用して、Equatable プロトコルに準拠しない型の要素を検索したり、特定の条件に一致する要素を検索したりすることができます。以下に、文字 "A" で始まる学生の名前を見つける例を示します。
let students = ["Kofi", "Abena", "Peter", "Kweku", "Akosua"]
if let i = students.firstIndex(where: { $0.hasPrefix("A") }) {
print("\(students[i]) starts with 'A'!")
}
// Prints "Abena starts with 'A'!"
複雑さ:O(n)、ここで n はコレクションの長さです。