常見(jiàn)語(yǔ)法
參數(shù)
Swift中帶參數(shù)的函數(shù)的一般寫(xiě)法是這樣的:
func someFunction(firstParameterName: Int, secondParameterName: Int) {
//在函數(shù)體內(nèi),firstParameterName 和 secondParameterName 代表參數(shù)中的第一個(gè)和第二個(gè)參數(shù)值
}
調(diào)用該函數(shù)時(shí),寫(xiě)法是:
someFunction(firstParameterName: 1, secondParameterName: 2)
但有時(shí)我們一些函數(shù)的參數(shù)前有一個(gè)“_”喧务,類(lèi)似這樣:
func someFunction(_ firstParameterName: Int, secondParameterName: Int) {
//在函數(shù)體內(nèi)哲思,firstParameterName 和 secondParameterName 代表參數(shù)中的第一個(gè)和第二個(gè)參數(shù)值
}
那么這個(gè)“_”是什么意思呢笔刹,看看函數(shù)的調(diào)用就知道了:
someFunction(1, secondParameterName: 2)
“_”是代表函數(shù)調(diào)用時(shí),可以忽略參數(shù)名稱(chēng)。
常見(jiàn)語(yǔ)法
nil是代表可選的缺省值
定義結(jié)構(gòu)體:strct Card {}
結(jié)構(gòu)體是值引用,每次都是拷貝一個(gè),但是是寫(xiě)時(shí)復(fù)制,也就是用的時(shí)候復(fù)制
類(lèi)是引用類(lèi)型,就是其他語(yǔ)言中傳遞的是指針,直接指向堆棧中的對(duì)象
實(shí)例變量初始化空數(shù)組:var card = Array()或者var cards = [Card](), ()就是調(diào)用構(gòu)造器,初始化的意思
0-100遍歷: for i in 0...100 {}
數(shù)組遍歷:for (index, title) in titles.enumerated()?{}
數(shù)組新增元素除了append還可以用+=, card += [card,card]
變量聲明:
var variableName = 42
var varB:Float
varB = 4.13
private lazy var scrollView: UIScrollView = {}
變量前加?表示如果沒(méi)有初值就是nil,加!表示明確這個(gè)變量一定有值,如果為空就會(huì)crash
extension,擴(kuò)展可以新增功能,但不能覆蓋現(xiàn)有的功能
與if語(yǔ)句相同的是配猫,guard也是基于一個(gè)表達(dá)式的布爾值去判斷一段代碼是否該被執(zhí)行毛俏。與if語(yǔ)句不同的是炭庙,guard只有在條件不滿(mǎn)足的時(shí)候才會(huì)執(zhí)行這段代碼。你可以把guard近似的看做是Assert煌寇,但是你可以?xún)?yōu)雅的退出而非崩潰焕蹄。
let表示不可變對(duì)象,也就是說(shuō)內(nèi)存地址不能改變,但也可以修飾可變對(duì)象
var表示可變對(duì)象
在閉包里面為了解決循環(huán)引用問(wèn)題,使用了`[unowned self]`阀溶。如果回調(diào)在self已經(jīng)被釋放后再調(diào)用腻脏,會(huì)導(dǎo)致crash掉。
解決:使用weak修飾银锻。
weak與unowned的區(qū)別:
unowned設(shè)置以后即使它原來(lái)引用的內(nèi)容已經(jīng)被釋放了迹卢,它仍然會(huì)保持對(duì)被已經(jīng)釋放了的對(duì)象的一個(gè) "無(wú)效的" 引用,它不能是 Optional 值徒仓,也不會(huì)被指向?nil?。如果你嘗試調(diào)用這個(gè)引用的方法或者訪問(wèn)成員屬性的話(huà)誊垢,程序就會(huì)崩潰掉弛。而?weak?則友好一些,在引用的內(nèi)容被釋放后喂走,標(biāo)記為?weak?的成員將會(huì)自動(dòng)地變成?nil?(因此被標(biāo)記為 @?weak?的變量一定需要是 Optional 值)殃饿。
元組:let x: (String, Int, Double) = (“hello”,5,0.8),
let (word, number,value) = x
print(word) print(number) print(value)
let x:(w:string, i:int,v:Double) = (“hello”,5,0.8),
print(x.w), print(x.i) print(x.v)
fileprivate文件內(nèi)可以互相訪問(wèn)
字典: var pantry:[String: Int] = [:]
?????panty[“apple”] = 2
?????panty = [“apple”:5,”pears”:3, “oranges”:4]
?????for (food, quantity) in panty { ???}
類(lèi)型
swift的Optional類(lèi)型其實(shí)是枚舉類(lèi)型,
enum Optional<T>{
case none
case some(<T>)
}
Optional通常有兩種類(lèi)型,一種是none,一種是關(guān)聯(lián)某個(gè)類(lèi)型(some<T>),使用?來(lái)訪問(wèn)可選類(lèi)型,??是指為空的話(huà)就創(chuàng)建個(gè)默認(rèn)值
var hello:String? ==> var hello: Optional<String> = .none
ex:
?let hello: String? = ...
print(hello!)相當(dāng)于強(qiáng)制解包,也就是
switch hello {
case .none: //raise an exception(crash)
case .some(let data): print(data)
}
var hello: String!
print(hello)同上面的switch是一個(gè)意思
var hello:String?=”hello” ==> var hello: Optional<String> = .some(“hello”)
var hello:String?=nil ?==> var hello: Optional<String> = .none
enum : enum food {
case fires
case dink(size: FryOrderSize)
case cookie(String, ounces:Int)
}
枚舉是個(gè)值類(lèi)型,和結(jié)構(gòu)體一樣
靜態(tài)函數(shù)調(diào)用
swift要調(diào)用不同文件中的func,需要將文件放在同一目錄,如果要將常量區(qū)分來(lái)看來(lái),可以對(duì)常量類(lèi)右鍵選擇 New Group from Selection
內(nèi)存管理
swift的內(nèi)存管理是計(jì)算管理(automatic reference counting,ARC),有人引用計(jì)數(shù)+1,離開(kāi)引用區(qū),計(jì)數(shù)-1,變?yōu)?后就立刻移除,ARC有三種類(lèi)型
strong,就是指該對(duì)象一直在堆的內(nèi)存中,是默認(rèn)類(lèi)型
weak,弱引用對(duì)象的引用計(jì)數(shù)不會(huì)+1,必須為可選變量
[if !supportLists]3.[endif]unowned,這是一個(gè)危險(xiǎn)類(lèi)型,無(wú)主引用,不把它算到引用計(jì)數(shù)里,非常少被使用芋肠,例如我使用了堆里的某個(gè)對(duì)象,但是不要把它算作強(qiáng)引用,我保證我從來(lái)不會(huì)在這個(gè)對(duì)象釋放后再去使用乎芳。我們很難說(shuō)我比機(jī)器更明白此時(shí)對(duì)象是否在堆中,唯一使用的情況是用來(lái)避免引用循環(huán)。引用循環(huán)是說(shuō)堆中有個(gè)對(duì)象引用了另一個(gè)對(duì)象,另一個(gè)對(duì)象又引用了該對(duì)象帖池,這樣就把對(duì)方留在了堆中奈惑。swift通常只有在閉包時(shí)會(huì)出現(xiàn)循環(huán)引用