Swift 진급―map 와 flatMap 의 사용
집합 에 맵 과 flatMap 을 사용 합 니 다.
먼저 다음 코드 를 보십시오.
func getInfos(by name: String) -> [String] {
if name == "Jack" {
return ["Male", "25", "New York"]
} else if name == "Lucy" {
return ["Female", "18", "London"]
} else {
return ["Unkown", "Unkown", "Unkown"]
}
}
let names = ["Jack", "Lucy", "Nobody"]
let infos1 = names.map { getInfos(by: $0) }
print(infos1)
let infos2 = names.flatMap { getInfos(by: $0) }
print(infos2)
입력 은 1 차원 배열 이 고 변환 후 infos 1 의 결 과 는 다음 과 같은 2 차원 배열 이기 때문에 map 후 2 층 구조 가 있 습 니 다.
[["Male", "25", "New York"], ["Female", "18", "London"], ["Unkown", "Unkown", "Unkown"]]
입력 은 1 차원 배열 입 니 다.변환 후 infos 2 의 결 과 는 다음 과 같은 1 차원 배열 이기 때문에 flatMap 후 에는 1 층 구조 만 있 습 니 다.
["Male", "25", "New York", "Female", "18", "London", "Unkown", "Unkown", "Unkown"]
map 가 Array 에서 의 실현 은 대체적으로 다음 과 같다.
extension Array {
func map<T>(_ transform: (Element) -> T) -> [T] {
var result: [T] = []
for x in self {
result.append(transform(x))
}
return result
}
}
flatMap 의 Array 에서 의 실현 은 대체적으로 다음 과 같다.
extension Array {
func flatMap<T>(_ transform: (Element) -> [T]) -> [T] {
var result: [T] = []
for x in self {
result.append(contentsOf: transform(x))
}
return result
}
}
선택 가능 한 유형 에 맵 과 flatMap 을 사용 합 니 다.다음 코드 에서 입력 은 string Numbers.first 입 니 다.그 유형 은 String 입 니까?
4.567917.전환 후 x 의 유형 은 Int??,그래서 맵 뒤에 2 층 Optional 이 있어 요
let stringNumbers = ["1", "2", "3", "foo"]
let x = stringNumbers.first.map { Int($0) } // Optional(Optional(1))
let y = stringNumbers.first.flatMap { Int($0) } // Optional(1)
map 가 optional 에서 의 실현 은 대체적으로 다음 과 같다.
extension Optional {
func map<U>(transform: (Wrapped) -> U) -> U? {
if let value = self {
return transform(value)
}
return nil
}
}
flatMap 의 optional 에서 의 실현 은 대체적으로 다음 과 같다.
extension Optional {
func flatMap<U>(transform: (Wrapped) -> U?) -> U? {
if let value = self, let transformed = transform(value) {
return transformed
}
return nil
}
}
이상 은 Swift 진급 입 니 다.-map 와 flatMap 의 상세 한 내용 을 자세히 설명 하고 Swift map 와 flatMap 에 관 한 자 료 는 저희 의 다른 관련 글 을 주목 하 세 요!
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
View의 레이아웃 방법을 AutoLayout에서 따뜻한 손 계산으로 하면 성능이 9.26배로 된 이야기이 기사는 의 15 일째 기사입니다. 어제는 에서 이었습니다. 손 계산을 권하는 의도는 없고, 특수한 상황하에서 계측한 내용입니다 화면 높이의 10 배 정도의 contentView가있는 UIScrollView 레이아...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.