一兽叮、什么是庫(kù)?
庫(kù)是共享程序代碼的方式猾愿,一般分為靜態(tài)庫(kù)和動(dòng)態(tài)庫(kù)鹦聪。
二、靜態(tài)庫(kù)與動(dòng)態(tài)庫(kù)的區(qū)別蒂秘?
靜態(tài)庫(kù):鏈接時(shí)完整地拷貝至可執(zhí)行文件中泽本,被多次使用就有多份冗余拷貝。
動(dòng)態(tài)庫(kù):鏈接時(shí)不復(fù)制姻僧,程序運(yùn)行時(shí)由系統(tǒng)動(dòng)態(tài)加載到內(nèi)存规丽,供程序調(diào)用,系統(tǒng)只加載一次撇贺,多個(gè)程序共用赌莺,節(jié)省內(nèi)存。
三显熏、iOS里靜態(tài)庫(kù)形式雄嚣?
.a和.framework
四、iOS里動(dòng)態(tài)庫(kù)形式喘蟆?
.dylib和.framework
五缓升、framework為什么既是靜態(tài)庫(kù)又是動(dòng)態(tài)庫(kù)?
系統(tǒng)的.framework是動(dòng)態(tài)庫(kù)蕴轨,我們自己建立的.framework是靜態(tài)庫(kù)港谊。
六、a與.framework有什么區(qū)別橙弱?
.a是一個(gè)純二進(jìn)制文件歧寺,.framework中除了有二進(jìn)制文件之外還有資源文件燥狰。
.a文件不能直接使用,至少要有.h文件配合斜筐,.framework文件可以直接使用龙致。
.a + .h + sourceFile = .framework。
建議用.framework.
七顷链、為什么要使用靜態(tài)庫(kù)目代?
方便共享代碼,便于合理使用嗤练。
實(shí)現(xiàn)iOS程序的模塊化榛了。可以把固定的業(yè)務(wù)模塊化成靜態(tài)庫(kù)煞抬。
和別人分享你的代碼庫(kù)霜大,但不想讓別人看到你代碼的實(shí)現(xiàn)。
開發(fā)第三方sdk的需要革答。
八战坤、制作靜態(tài)庫(kù)時(shí)的幾點(diǎn)注意:
1 注意理解:無論是.a靜態(tài)庫(kù)還.framework靜態(tài)庫(kù),我們需要的都是二進(jìn)制文件+.h+其它資源文件的形式蝗碎,不同的是湖笨,.a本身就是二進(jìn)制文件,需要我們自己配上.h和其它文件才能使用蹦骑,而.framework本身已經(jīng)包含了.h和其它文件,可以直接使用臀防。
2 圖片資源的處理:兩種靜態(tài)庫(kù)眠菇,一般都是把圖片文件單獨(dú)的放在一個(gè).bundle文件中,一般.bundle的名字和.a或.framework的名字相同袱衷。.bundle文件很好弄捎废,新建一個(gè)文件夾,把它改名為.bundle就可以了致燥,右鍵登疗,顯示包內(nèi)容可以向其中添加圖片資源。
3 category是我們實(shí)際開發(fā)項(xiàng)目中經(jīng)常用到的嫌蚤,把category打成靜態(tài)庫(kù)是沒有問題的辐益,但是在用這個(gè)靜態(tài)庫(kù)的工程中,調(diào)用category中的方法時(shí)會(huì)有找不到該方法的運(yùn)行時(shí)錯(cuò)誤(selector not recognized)脱吱,解決辦法是:在使用靜態(tài)庫(kù)的工程中配置other linker flags的值為-ObjC智政。
4 如果一個(gè)靜態(tài)庫(kù)很復(fù)雜,需要暴露的.h比較多的話箱蝠,就可以在靜態(tài)庫(kù)的內(nèi)部創(chuàng)建一個(gè).h文件(一般這個(gè).h文件的名字和靜態(tài)庫(kù)的名字相同)续捂,然后把所有需要暴露出來的.h文件都集中放在這個(gè).h文件中垦垂,而那些原本需要暴露的.h都不需要再暴露了,只需要把.h暴露出來就可以了牙瓢。
九劫拗、補(bǔ)充
在 iOS 8 之前,iOS 平臺(tái)不支持使用動(dòng)態(tài) Framework矾克,開發(fā)者可以使用的 Framework 只有蘋果自家的 UIKit.Framework杨幼,F(xiàn)oundation.Framework 等。這種限制可能是出于安全的考慮聂渊。換一個(gè)角度講差购,因?yàn)?iOS 應(yīng)用都是運(yùn)行在沙盒當(dāng)中,不同的程序之間不能共享代碼汉嗽,同時(shí)動(dòng)態(tài)下載代碼又是被蘋果明令禁止的欲逃,沒辦法發(fā)揮出動(dòng)態(tài)庫(kù)的優(yōu)勢(shì),實(shí)際上動(dòng)態(tài)庫(kù)也就沒有存在的必要了饼暑。
由于上面提到的限制稳析,開發(fā)者想要在 iOS 平臺(tái)共享代碼,唯一的選擇就是打包成靜態(tài)庫(kù) .a 文件弓叛,同時(shí)附上頭文件(例如微信的SDK)彰居。但是這樣的打包方式不夠方便,使用時(shí)也比較麻煩撰筷,大家還是希望共享代碼都能能像 Framework 一樣陈惰,直接扔到工程里就可以用。于是人們想出了各種奇技淫巧去讓 Xcode Build 出 iOS 可以使用的 Framework毕籽,這種方法產(chǎn)生的 Framework 還有 “偽”(Fake) Framework 和 “真”(Real) Framework 的區(qū)別抬闯。
iOS 8/Xcode 6 推出之后,iOS 平臺(tái)添加了動(dòng)態(tài)庫(kù)的支持关筒,同時(shí) Xcode 6 也原生自帶了 Framework 支持(動(dòng)態(tài)和靜態(tài)都可以)溶握,上面提到的的奇技淫巧也就沒有必要了。為什么 iOS 8 要添加動(dòng)態(tài)庫(kù)的支持蒸播?唯一的理由大概就是 Extension 的出現(xiàn)睡榆。Extension 和 App 是兩個(gè)分開的可執(zhí)行文件,同時(shí)需要共享代碼袍榆,這種情況下動(dòng)態(tài)庫(kù)的支持就是必不可少的了胀屿。但是這種動(dòng)態(tài) Framework 和系統(tǒng)的 UIKit.Framework 還是有很大區(qū)別。系統(tǒng)的 Framework 不需要拷貝到目標(biāo)程序中蜡塌,我們自己做出來的 Framework 哪怕是動(dòng)態(tài)的碉纳,最后也還是要拷貝到 App 中(App 和 Extension 的 Bundle 是共享的),因此蘋果又把這種 Framework 稱為 Embedded Framework(可植入性Framework)馏艾。
態(tài)度決定一切