如果你做ios開發(fā)比較早的話,在以前做ios項(xiàng)目開發(fā)的時(shí)候,無論是引用系統(tǒng)的framework還是第三方的framework我們一般都需要先在build phases里添加framework:
但是現(xiàn)在脉课,不知道大家有留意過沒博助,我們不再需要顯性的添加任何庫麻削,如下圖
那么是什么原因呢娇跟?
通過排查是xcode5以后就不需要再顯性的添加framework了,那么xcode5以后有什么新的功能特性變動(dòng)嗎头遭?通過查看蘋果wwdc2013的文檔說明寓免,找到了OC有這么個(gè)新的特性:
modules癣诱、AutoLinking和@import
modules是用來做什么的呢?
這個(gè)時(shí)候我們不得不提到我們的import關(guān)鍵字袜香,這個(gè)是用來引入頭文件的撕予,它和C語言的include一樣,都是把文件都復(fù)制粘貼一遍進(jìn)行引用到當(dāng)前文件困鸥,不過import做了一個(gè)處理嗅蔬,能減少重復(fù)引用剑按,比如:
文件A和B都import了文件C疾就,文件D又都import了A和B,這個(gè)時(shí)候import不會(huì)重復(fù)引用C艺蝴,具體的方法是通過ifndef來實(shí)現(xiàn)猬腰;
但是,當(dāng)程序復(fù)雜的時(shí)候猜敢,經(jīng)常會(huì)到處引用同一個(gè)文件姑荷,用import關(guān)鍵字,這樣編譯時(shí)所占用的代碼劇增缩擂,所以在ios里提供了預(yù)編譯文件pch(PreCompiled ?Header)鼠冕,把常用的頭文件進(jìn)行預(yù)編譯,這樣就減少了編譯時(shí)間和編譯代碼胯盯。
但是呢懈费!又會(huì)出現(xiàn)新的問題:放在pch的頭文件,在整個(gè)工程中都能訪問博脑,編譯器也不會(huì)報(bào)錯(cuò)和警告憎乙,這樣增加了代碼出錯(cuò)的可能性。
所以蘋果引入了modules叉趣,簡單來說modules是對framework進(jìn)行了封裝泞边,文件編譯時(shí),有一個(gè)已編譯modules文件列表疗杉,再編譯一個(gè)文件時(shí)阵谚,會(huì)首先從已編譯文件里面尋找,如果存在則使用已經(jīng)編譯了的文件烟具,如果沒有椭蹄,再添加進(jìn)來,這樣每一個(gè)文件只會(huì)被編譯一次净赴,而開發(fā)過程中又不會(huì)被意外使用到绳矩,這樣就把import和pch的兩個(gè)問題同時(shí)解決了。(不知大家注意到?jīng)]玖翅,xcode7以后新建工程不再默認(rèn)生成pch文件了翼馆,原理也在此)
原理說明白后割以,那么怎么使用modules呢?這就是我們要說的AutoLinking和@import了应媚!
通過@import严沥,告訴編譯器去使用modules的引用形式。
@import UIKit 等價(jià)于 #import 只是用modules特性中姜,而引用某個(gè)特性的文件消玄,如#import ,則寫作:@import UIKit.UIApplication
@import還有一個(gè)大的好處是:不需要在project setting里添加framework了丢胚,通過AutoLinking翩瓜,xcode的編譯器LLVM會(huì)在編譯階段將所涉及到的框架自動(dòng)幫你寫到link里,不需要在build phases里手動(dòng)添加了携龟。
那么如果我們不用@import兔跌,用#import,是不是得手動(dòng)把#改成@呢峡蟋?
xcode5后坟桅,默認(rèn)開啟了modules,這個(gè)時(shí)候的#import會(huì)映射成@import蕊蝗,達(dá)到同樣的效果仅乓,大家可以在你們的Xcode 里查看下圖的配置是不是默認(rèn)如此:
所以我們在xcode里寫代碼的時(shí)候,在以前我們需要用到系統(tǒng)framework的時(shí)候都得顯性的添加到Build Phases里蓬戚,而現(xiàn)在我們不需要了夸楣!