Swift 進(jìn)階 —— map 和 flatMap的使用
map 和 flatMap 主要分在集合上的使用和在可選類型上的使用,下面分別來(lái)看下。
集合上使用 map 和 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)
輸入是一個(gè)一維數(shù)組,轉(zhuǎn)換后 infos1 的結(jié)果是如下的一個(gè)二維數(shù)組,所以 map 后有兩層結(jié)構(gòu):
[["Male", "25", "New York"], ["Female", "18", "London"], ["Unkown", "Unkown", "Unkown"]]
輸入是一個(gè)一維數(shù)組,轉(zhuǎn)換后 infos2 的結(jié)果是如下的一個(gè)一維數(shù)組,所以 flatMap 后只有一層結(jié)構(gòu):
["Male", "25", "New York", "Female", "18", "London", "Unkown", "Unkown", "Unkown"]
map 在 Array 上的實(shí)現(xiàn)大致如下:
extension Array {
func map<T>(_ transform: (Element) -> T) -> [T] {
var result: [T] = []
for x in self {
result.append(transform(x))
}
return result
}
}
flatMap 在 Array 上的實(shí)現(xiàn)大致如下:
extension Array {
func flatMap<T>(_ transform: (Element) -> [T]) -> [T] {
var result: [T] = []
for x in self {
result.append(contentsOf: transform(x))
}
return result
}
}
可選類型上使用 map 和 flatMap
如下代碼中,輸入是 stringNumbers.first,其類型是 String?
- 轉(zhuǎn)換后 x 的類型是 Int??,所以 map 后有兩層 Optional
- 轉(zhuǎn)換后 y 的類型是 Int?,所以 flatMap 后只有一層 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 上的實(shí)現(xiàn)大致如下:
extension Optional {
func map<U>(transform: (Wrapped) -> U) -> U? {
if let value = self {
return transform(value)
}
return nil
}
}
flatMap 在 Optional 上的實(shí)現(xiàn)大致如下:
extension Optional {
func flatMap<U>(transform: (Wrapped) -> U?) -> U? {
if let value = self, let transformed = transform(value) {
return transformed
}
return nil
}
}
以上就是Swift 進(jìn)階 - 詳解map 和 flatMap的詳細(xì)內(nèi)容,更多關(guān)于Swift map 和 flatMap的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
iOS路由(MGJRouter)的實(shí)現(xiàn)
這篇文章主要介紹了iOS路由(MGJRouter)的實(shí)現(xiàn),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-09-09
IOS開(kāi)發(fā)中NSURL的基本操作及用法詳解
NSURL其實(shí)就是我們?cè)跒g覽器上看到的網(wǎng)站地址,這不就是一個(gè)字符串么,為什么還要在寫一個(gè)NSURL呢,主要是因?yàn)榫W(wǎng)站地址的字符串都比較復(fù)雜,包括很多請(qǐng)求參數(shù),這樣在請(qǐng)求過(guò)程中需要解析出來(lái)每個(gè)部門,所以封裝一個(gè)NSURL,操作很方便2015-12-12
iOS 標(biāo)簽Tag列表的實(shí)現(xiàn)代碼
這篇文章主要介紹了本篇文章主要介紹了iOS 標(biāo)簽Tag列表的實(shí)現(xiàn)代碼,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2017-04-04
總結(jié)iOS開(kāi)發(fā)中的斷點(diǎn)續(xù)傳與實(shí)踐
本文先從斷點(diǎn)續(xù)傳問(wèn)題開(kāi)始,介紹斷點(diǎn)續(xù)傳概述和原理。接著結(jié)合筆者調(diào)研中嘗試的 AFHTTPRequestOpeartion,簡(jiǎn)單分析源碼。最后分別基于 NSURLConnection,NSURLSessionDataTask 和 NSURLSessionDownloadTask 去實(shí)現(xiàn)應(yīng)用重啟情況下的斷點(diǎn)續(xù)傳。下面一起來(lái)看看。2016-07-07
IOS 單擊手勢(shì)的添加實(shí)現(xiàn)代碼
這篇文章主要介紹了IOS 單擊手勢(shì)的添加實(shí)現(xiàn)代碼的相關(guān)資料,需要的朋友可以參考下2017-05-05
iOS開(kāi)發(fā)中CAlayer層的屬性以及自定義層的方法
這篇文章主要介紹了iOS開(kāi)發(fā)中CAlayer層的屬性以及自定義層的方法,代碼基于傳統(tǒng)的Objective-C,需要的朋友可以參考下2015-11-11
IOS實(shí)現(xiàn)輸入驗(yàn)證碼、密碼按位分割(二)
這篇文章主要介紹了IOS實(shí)現(xiàn)輸入驗(yàn)證碼、密碼按位分割的方法,在App內(nèi),密碼及驗(yàn)證碼的輸入,采用按位輸入的方法,且位與位之間有分隔線,感興趣的小伙伴們可以參考一下2016-01-01

