Swift2.0標(biāo)準(zhǔn)庫(kù)函數(shù)整理

簡(jiǎn)介:
Swift發(fā)布后提供了很多高效的標(biāo)準(zhǔn)庫(kù)函數(shù),其實(shí)早在 Swift 正式發(fā)布之前沛善,iOS / Cocoa 開(kāi)發(fā)者都可以使用諸如 ObjectiveSugar 或者 ReactiveCocoa 第三方庫(kù)金刁,實(shí)現(xiàn)類似 map、flatMap 或 filter 等函數(shù)式編程的構(gòu)建媳友。
并且通過(guò)使用函數(shù)式編程能夠更好地表達(dá)你的意圖醇锚,減少代碼的行數(shù)焊唬,以及使用鏈?zhǔn)浇Y(jié)構(gòu)構(gòu)建復(fù)雜的邏輯看靠,更顯清爽。

接下來(lái),介紹一下常用的一些標(biāo)準(zhǔn)庫(kù)函數(shù):

1.在文檔中提到的庫(kù)函數(shù)(The Swift Programming Language)

//斷言芳杏,參數(shù)如果為true則繼續(xù)爵赵,否則拋出異常
assert(true)
//swift 1.0 計(jì)算序列的元素個(gè)數(shù)
let str = "sk87v5"
countElements("str") == 6

//swift2.0后計(jì)算字符串長(zhǎng)度
print(str.characters.count)//6

//swift2.0后計(jì)算數(shù)組元素
let arr = ["sk", "wyj", "jj"]
print(arr.count)//3
//返回一個(gè)新的序列空幻,其中每個(gè)元素是一個(gè)元組秕铛,第一個(gè)值為原來(lái)元素所在的位置index但两,第二個(gè)為原來(lái)序列中的元素
let array = ["N", "B","A"]
for (i, j) in array.enumerate() {
    print("\(i):\(j)")
}
打印結(jié)果:
//0:N
//1:B
//2:A

//返回所有參數(shù)中的最小值
min(9, 2, 4) == 2
//打印
print("Hello")
//Swift1.0 使用的打印 (帶換行)
// println mentioned on page 4
println("World")
//排序
// sort mentioned on page 14
let array = ["N", "B","A"]
for i in array.sort() {
    print(i) // A B N
}

2.文檔未提的實(shí)用函數(shù)

  • Swift 1.0
  • map(sequence, transformClosure):對(duì)數(shù)組中每個(gè)元素都執(zhí)行閉包谨湘,并將所有閉包的結(jié)果合成一個(gè)新數(shù)組并返回紧阔。
  • Swift 2.0
  • map(transform: (Int) throws -> T):對(duì)數(shù)組中每個(gè)元素都執(zhí)行閉包中的操作擅耽,并將所有閉包的結(jié)果合成一個(gè)新序列數(shù)組并返回。

//swift 2.0
let array = [1, 10, 22, 40, 88, 90, 99]
//1.常規(guī)用法
let newArr = array.map { (a : Int) -> Int in
    return a + 10
}
print(newArr)

//2.簡(jiǎn)化用法
let newArr = array.map({$0 + 10})
print(newArr)
//打印結(jié)果:
[11, 20, 32, 50, 98, 100, 109]

  • (Swift 1.0)
  • filter(sequence, includeElementClosure):
  • (Swift 2.0)
  • filter(includeElement: (Int) throws -> Bool)
    對(duì)序列數(shù)組中每個(gè)元素都執(zhí)行includeElement閉包憾儒,并將所有閉包結(jié)果為true的元素合成一個(gè)新數(shù)組并返回起趾。
//swift 2.0
let array = [1, 10, 22, 40, 88, 90, 99]
//1.常規(guī)用法
let newArr = array.filter { (a : Int) -> Bool in
    return a % 10 == 0
}
print(newArr)//[10, 40, 90]\n

//2.簡(jiǎn)化用法
let newArr = array.filter({$0 % 10 == 0})
print(newArr)//[10, 40, 90]\n

  • Swift 1.0
  • reduce(sequence, initial, combineClosure):給定一個(gè)數(shù)組sequence,以及一個(gè)初始值initial冷蚂,然后將initial和數(shù)組里的第1個(gè)元素作為參數(shù)傳入combineClosure閉包中進(jìn)行運(yùn)算,得到的結(jié)果保存到initial艺骂;然后再將initial和第2個(gè)元素傳入combineClosure閉包中計(jì)算钳恕,結(jié)果保存到initial忧额;重復(fù)計(jì)算直到所有sequence中的元素都計(jì)算完畢睦番,并返回最終的initial值耍属。
  • Swift 2.0
  • reduce(initial: T, combine: (T, String) throws -> T)
//1.傳統(tǒng)求和
let arrNum = [1, 2, 3, 4 ,5]
var sum = 0
for num in arrNum {
    sum = sum + num
}
print(sum) //15

//2.傳統(tǒng)求積
var a = 1
for num in arrNum {
    a = a * num
}
print(a)//120

//2.reduce求和,求積:
let arrNum = [1, 2, 3, 4, 5]
//簡(jiǎn)化一:
let sum = arrNum.reduce(0, combine: {$0 + $1})
let a = arrNum.reduce(1, combine: {$0 * $1})

//簡(jiǎn)化二:
//初始值 initial 為 0,每次遍歷數(shù)組元素示启,執(zhí)行 + 操作
let sum = arrNum.reduce(0, combine: +)
//初始值 initial 為 1夫嗓,每次遍歷數(shù)組元素,執(zhí)行 * 操作
let a = arrNum.reduce(1, combine: *)

print(sum)
print(a)

let arr = ["sk", "wyj", "jj", "dyf", "zjz"]
let arrNew = arr.reduce("87v5", combine: + )
print(arrNew)

  • abs(signedNumber):返回?cái)?shù)字的絕對(duì)值
abs(-1) == 1 //true
abs(-42) == 42 //true
abs(42) == 42 //true
  • contains(sequence, element):
  • 如果某個(gè)序列sequence(比如說(shuō)一個(gè)數(shù)組)包含指定的元素element劳跃,則返回true,否則返回false刨仑。
let arr = ["sk", "wyj", "jj", "dyf", "zjz"]
arr.contains("sk")// true
arr.contains("87v5")// false
  • dropFirst(sequence):
  • 返回一個(gè)去掉了首個(gè)元素的辙诞、新的序列(比如一個(gè)新數(shù)組)飞涂。
let array = ["xmg", "sk", "why"]
var arrayNew = array.dropFirst() //["sk", "why"]
//去掉前2個(gè)元素
var arrayNewTwo = array.dropFirst(2) //["why"]
//注:elementsEqual() iOS9.0后可用
arrayNew.elementsEqual(array) //false

  • dropLast(sequence):返回一個(gè)去掉了最后一個(gè)元素的祈搜、新的序列(比如一個(gè)新數(shù)組)。
let array = ["xmg", "sk", "why"]
var arrayNew = array.dropLast() //["xmg", "sk"]
//去掉后2個(gè)元素
var arrayNewTwo = array.dropLast(2) //["xmg"]
arrayNew.elementsEqual(["xmg", "sk"])  //true
  • dump(object):打印出某個(gè)對(duì)象object的所有信息
let array = ["xmg", "sk", "why"]
dump(array) //["xmg", "sk", "why"]
// Prints:
//3 elements
//- [0]: xmg
//- [1]: sk
//- [2]: why

//注:dump和print的區(qū)別:dump打印的是內(nèi)容,print打印的是內(nèi)容+ 換行符的字符串
print(array)//"["xmg", "sk", "why"]\n"

  • elementsEqual():判斷兩個(gè)序列是否相等
let array = ["xmg", "sk", "why"]
array.elementsEqual(["sk"]) //false

let arrayOne = array.dropLast()
let arrayTwo = ["xmg", "sk"]
arrayOne.elementsEqual(arrayTwo) //true
  • (Swift1.0)
  • find(sequence, element):返回序列sequence中某元素element的位置index。如果序列中不存在此元素蘸秘,則返回nil醋虏。
  • (Swift2.0)
  • arr.indexOf(element: String):返回?cái)?shù)組中某元素element的位置index颈嚼。如果數(shù)組中不存在此元素粘舟,則返回nil
//find(sequence, element)
let arr = ["sk", "wyj", "jj"]
find(arr, "sk") == 0
find(arr, "dyf") == nil
find([29, 85, 42, 96, 75], 42) == 2

//indexOf(element: String)
let arr = ["sk", "wyj", "jj"]
let index = arr.indexOf("sk") //0
let index2 = arr.indexOf("dyf")//nil

  • (Swift 1.0)
  • indices(sequence):返回序列sequence中所有元素的位置(indices是index的復(fù)數(shù))
  • (Swift 2.0)
  • 改為屬性indices,返回Range類型
//swift1.0
equal(indices([29, 85, 42]), [0, 1, 2])
for i in indices([29, 85, 42]) {
    // 0, 1, 2
    print(i)
}

//swift2.0
let arr = ["sk", "wyj", "jj"]
let a = arr.indices
print(a) //0..<3

  • (Swift1.0)
  • join(separator, sequence):將序列sequence通過(guò)分隔符separator連成一個(gè)字符串柑肴,并返回此字符串晰骑。
  • (Swift2.0)
  • joinWithSeparator(separator: String)
//swift1.0
join(":", ["A", "B", "C"]) == "A:B:C"
let arr = ["sk", "wyj", "jj"]
join("/", arr) == "sk/wyj/jj"

//swift2.0
let arr = ["sk", "wyj", "jj"]
let joinArr = arr.joinWithSeparator("/")
print(joinArr)
打印結(jié)果:
sk/wyj/jj

  • max(comparable1, comparable2, etc.):返回參數(shù)中的最大值。
max(0, 1) == 1
max(8, 2, 3) == 8
  • maxElement(sequence):返回序列sequence中的最大值骤公。
//swift 1.0
let array = [1, 10, 22, 40, 88, 90, 99]
maxElement(array) //99

//swift 2.0
let array = [1, 10, 22, 40, 88, 90, 99]
array.maxElement() //99

  • minElements(sequence):返回序列sequence中的最小值扬跋。
//swift 1.0
let array = [1, 10, 22, 40, 88, 90, 99]
minElement(array) //1

//swift 2.0
let array = [1, 10, 22, 40, 88, 90, 99]
array.minElement() //1

  • reverse(sequence):返回逆序的序列sequence。
let array = [1, 10, 22, 40, 88, 90, 99]
for i in array.reverse() {
    print(i)
}
  • Swift 1.0
  • startsWith(sequence1, sequence2):如果序列sequence1中開(kāi)頭的元素跟序列sequence2中的所有元素都相等洒试,則返回true,否則返回false痪宰。
  • Swift 2.0
  • startsWith(other: SequenceType)
//swift 1.0
startsWith(1..20, 1..5) == true

let arr1 = ["sk", "wyj", "jj"]
let arr2 = ["sk"]
startsWith(arr1, arr2) == true

//swift 2.0
let range1 = 1..<20
let range2 = 1..<5
if range1.startsWith(range2) {
    print("range2所有元素和range1開(kāi)頭元素相等")
}else {
    print("不相等")
}

let arr1 = ["sk", "wyj", "jj"]
let arr2 = ["sk"]
if arr1.startsWith(arr2) {
    print("arr2所有元素和arr1開(kāi)頭所有元素相等")
}else {
    print("不相等")
}

附:Swift1.0 中74個(gè)內(nèi)置函數(shù):

abs(...)
advance(...)
alignof(...)
alignofValue(...)
assert(...)
bridgeFromObjectiveC(...)
bridgeFromObjectiveCUnconditional(...)
bridgeToObjectiveC(...)
bridgeToObjectiveCUnconditional(...)
c_malloc_size(...)
c_memcpy(...)
c_putchar(...)
contains(...)
count(...)
countElements(...)
countLeadingZeros(...)
debugPrint(...)
debugPrintln(...)
distance(...)
dropFirst(...)
dropLast(...)
dump(...)
encodeBitsAsWords(...)
enumerate(...)
equal(...)
filter(...)
find(...)
getBridgedObjectiveCType(...)
getVaList(...)
indices(...)
insertionSort(...)
isBridgedToObjectiveC(...)
isBridgedVerbatimToObjectiveC(...)
isUniquelyReferenced(...)
join(...)
lexicographicalCompare(...)
map(...)
max(...)
maxElement(...)
min(...)
minElement(...)
numericCast(...)
partition(...)
posix_read(...)
posix_write(...)
print(...)
println(...)
quickSort(...)
reduce(...)
reflect(...)
reinterpretCast(...)
reverse(...)
roundUpToAlignment(...)
sizeof(...)
sizeofValue(...)
sort(...)
split(...)
startsWith(...)
strideof(...)
strideofValue(...)
swap(...)
swift_MagicMirrorData_summaryImpl(...)
swift_bufferAllocate(...)
swift_keepAlive(...)
toString(...)
transcode(...)
underestimateCount(...)
unsafeReflect(...)
withExtendedLifetime(...)
withObjectAtPlusZero(...)
withUnsafePointer(...)
withUnsafePointerToObject(...)
withUnsafePointers(...)
withVaList(...)

codeStraight原創(chuàng)文章,如有錯(cuò)誤,歡迎指正!
http://www.reibang.com/p/2c7407c76ad8

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市垢粮,隨后出現(xiàn)的幾起案子蜡吧,更是在濱河造成了極大的恐慌占键,老刑警劉巖昔善,帶你破解...
    沈念sama閱讀 218,122評(píng)論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異畔乙,居然都是意外死亡君仆,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,070評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門牲距,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)返咱,“玉大人,你說(shuō)我怎么就攤上這事牍鞠】。” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,491評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵难述,是天一觀的道長(zhǎng)吐句。 經(jīng)常有香客問(wèn)我屯断,道長(zhǎng)紧武,這世上最難降的妖魔是什么朋鞍? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,636評(píng)論 1 293
  • 正文 為了忘掉前任坎吻,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好仲闽,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,676評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布畏鼓。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪痛阻。 梳的紋絲不亂的頭發(fā)上糜工,一...
    開(kāi)封第一講書(shū)人閱讀 51,541評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的卖子。 我是一名探鬼主播,決...
    沈念sama閱讀 40,292評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼这弧,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼卷哩!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起礼预,我...
    開(kāi)封第一講書(shū)人閱讀 39,211評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤励堡,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后揩慕,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體劲藐,經(jīng)...
    沈念sama閱讀 45,655評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡二拐,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,846評(píng)論 3 336
  • 正文 我和宋清朗相戀三年厌漂,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了旨椒。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,965評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出弧圆,到底是詐尸還是另有隱情历造,我是刑警寧澤,帶...
    沈念sama閱讀 35,684評(píng)論 5 347
  • 正文 年R本政府宣布刻剥,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜碟联,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,295評(píng)論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧往声,春花似錦塘雳、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,894評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至炊苫,卻和暖如春声畏,著一層夾襖步出監(jiān)牢的瞬間才睹,已是汗流浹背坞琴。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,012評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工荧关, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人参萄。 一個(gè)月前我還...
    沈念sama閱讀 48,126評(píng)論 3 370
  • 正文 我出身青樓筒溃,卻偏偏與公主長(zhǎng)得像迁央,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,914評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容