iOS 開發(fā)APP指令集以及兼容的SDK指令集設(shè)置

前言:

指令集的概念:CPU指令集定義的是一個(gè)中央處理器所應(yīng)該提供的基礎(chǔ)功能的集合医男,它是一個(gè)標(biāo)準(zhǔn)是一個(gè)接口也是一個(gè)協(xié)議。在軟件開發(fā)中具有協(xié)議和接口定義的概念蹬癌,無論是消費(fèi)者還是提供者都需要遵循這個(gè)標(biāo)準(zhǔn)來進(jìn)行編程和交互:提供者要實(shí)現(xiàn)接口所具有的功能权她,至于如何實(shí)現(xiàn)則是內(nèi)部的事情,不對外暴露逝薪,消費(fèi)者也不需要知道具體的實(shí)現(xiàn)細(xì)節(jié)隅要;消費(fèi)者則總是要按接口提供的功能方法并組合使用來完成某種功能。這種設(shè)計(jì)的思維對于硬件系統(tǒng)也是一樣適用的董济。一般情況下某種CPU指令集通常都是由某些設(shè)計(jì)或者生產(chǎn)CPU的公司或者某標(biāo)準(zhǔn)組織共同定義而形成

1步清、ARM

ARM處理器,特點(diǎn)是體積小虏肾、低功耗廓啊、低成本、高性能封豪,所以幾乎所有手機(jī)處理器都基于ARM谴轮,在嵌入式系統(tǒng)中應(yīng)用廣泛。

2吹埠、ARM處理器指令集

armv6|armv7|armv7s|arm64都是ARM處理器的指令集第步,這些指令集都是向下兼容的,例如armv7指令集兼容armv6缘琅,只是使用armv6的時(shí)候無法發(fā)揮出其性能粘都,無法使用armv7的新特性,從而會導(dǎo)致程序執(zhí)行效率沒那么高胯杭。

還有兩個(gè)我們也很熟悉的指令集:i386|x86_64 是Mac處理器的指令集驯杜,i386是針對intel通用微處理器32架構(gòu)的。x86_64是針對x86架構(gòu)的64位處理器做个。所以當(dāng)使用iOS模擬器的時(shí)候會遇到i386|x86_64鸽心,iOS模擬器沒有arm指令集。


在iOS項(xiàng)目中難免都會看到armv7居暖, armv7s 顽频,arm64,i386太闺,x86_64,以及最新xcode10 才加入的arm64e,但是他們具體是干啥的呢糯景?下面我來簡單的說一下。

arm64:iPhone6s | iphone6s plus|iPhone6| iPhone6 plus|iPhone5S | iPad Air| iPad mini2(iPad miniwithRetina Display)

armv7s:iPhone5|iPhone5C|iPad4(iPadwithRetina Display)

armv7:iPhone4|iPhone4S|iPad|iPad2|iPad3(The New iPad)|iPad mini|iPod Touch3G|iPod Touch4

這些都是在實(shí)際iOS開發(fā)真機(jī)中用到的

i386是針對intel通用微處理器32位處理器

x86_64是針對x86架構(gòu)的64位處理器

模擬器32位處理器測試需要i386架構(gòu),

模擬器64位處理器測試需要x86_64架構(gòu)蟀淮,

真機(jī)32位處理器需要armv7,或者armv7s架構(gòu)最住,

真機(jī)64位處理器需要arm64架構(gòu)。

這里面還有一個(gè)需要注意的點(diǎn)就是armv7 可以兼容armv7s相關(guān)的指令集怠惶,其實(shí)在真機(jī)項(xiàng)目中可以直接刪除掉armv7s涨缚,這樣可以節(jié)省一部分的包大小。


一策治、 在實(shí)際開發(fā)中的選擇問題

Xcode中指令集相關(guān)選項(xiàng)(Build Setting中)

Architectures

指定工程被編譯成可支持哪些指令集類型脓魏,而支持的指令集越多,就會編譯出包含多個(gè)指令集代碼的數(shù)據(jù)包通惫,對應(yīng)生成二進(jìn)制包就越大茂翔,也就是ipa包會變大。

Valid Architectures

限制可能被支持的指令集的范圍履腋,也就是Xcode編譯出來的二進(jìn)制包類型最終從這些類型產(chǎn)生珊燎,而編譯出哪種指令集的包,將由Architectures與Valid Architectures(因此這個(gè)不能為空)的交集來確定

Build Active Architecture Only

指定是否只對當(dāng)前連接設(shè)備所支持的指令集編譯

當(dāng)其值設(shè)置為YES府树,這個(gè)屬性設(shè)置為yes俐末,是為了debug的時(shí)候編譯速度更快,它只編譯當(dāng)前的architecture版本奄侠,而設(shè)置為no時(shí)卓箫,會編譯所有的版本。 所以垄潮,一般debug的時(shí)候可以選擇設(shè)置為yes烹卒,release的時(shí)候要改為no,以適應(yīng)不同設(shè)備弯洗。

舉例

比如Valid Architectures設(shè)置的支持arm指令集版本有:armv7/armv7s/arm64旅急,對應(yīng)的Architectures設(shè)置的支持arm指令集版本有:armv7s,這時(shí)Xcode只會生成一個(gè)armv7s指令集的二進(jìn)制包牡整。

再比如:將Architectures支持arm指令集設(shè)置為:armv7,armv7s藐吮,對應(yīng)的Valid Architectures的支持的指令集設(shè)置為:armv7s,arm64,那么此時(shí)逃贝,XCode生成二進(jìn)制包所支持的指令集只有armv7s

Valid Architectures? 設(shè)置里谣辞, 默認(rèn)為 Standard architectures(armv7,arm64),如果你想改的話,自己在other中更改

使用standard architectures (including 64-bit)(armv7,arm64)參數(shù)沐扳,則打的包里面有32位泥从、64位兩份代碼,在iPhone5s( iPhone5s的cpu是64位的 )下沪摄,會首選運(yùn)行64位代碼包躯嫉, 其余的iPhone( 其余iPhone都是32位的,iPhone5c也是32位 )纱烘,只能運(yùn)行32位包,但是包含兩種架構(gòu)的代碼包祈餐,只有運(yùn)行在ios6以上的系統(tǒng)上擂啥。

而使用standard architectures (armv7,armv7s)參數(shù), 則打的包里只有32位代碼帆阳, iPhone5s的cpu是64位啤它,但是可以兼容32位代碼,即可以運(yùn)行32位代碼舱痘。但是這會降低iPhone5s的性能。 其余的iPhone對32位代碼包更沒問題离赫, 而32位代碼包芭逝,對系統(tǒng)也幾乎也沒什么限制。

所以總結(jié)如下:? 要發(fā)揮iPhone5s的64位性能渊胸,就要包含64位包旬盯,那么系統(tǒng)最低要求為ios6。 如果要兼容ios5以及更低的系統(tǒng)翎猛,只能打32位的包胖翰,系統(tǒng)都能通用,但是會喪失iPhone5s的性能切厘。

當(dāng)然這樣做會使部分設(shè)備出現(xiàn)性能損失萨咳,當(dāng)然在普通應(yīng)用中這點(diǎn)體現(xiàn)幾乎感覺不到,至少不會威脅到用戶體檢疫稿。


二培他、制作靜態(tài)庫.a以及.framework時(shí)指令集選擇

現(xiàn)在回歸到正題,如何制作一個(gè)“沒有問題”的.a靜態(tài)庫遗座,通過以上信息了解到舀凛,當(dāng)我們做App的時(shí)候,為了追求高效率途蒋,并且減小包的大小猛遍,Build Active Architecture Only設(shè)置成YES,Architectures按Xcode默認(rèn)配置就可以号坡,因?yàn)閍rm64向前兼容懊烤。但制作.a靜態(tài)庫就不同了,因?yàn)橐WC兼容性筋帖,包括不同iOS設(shè)備以及模擬器運(yùn)行不出錯奸晴,所以結(jié)合當(dāng)前行業(yè)情況,要做到最大的兼容性日麸。

ValidArchitectures設(shè)置為:armv7|armv7s|arm64|i386|x86_64?

Architectures設(shè)置不變(或根據(jù)你需要): ?armv7|arm64

然后分別選擇iOS設(shè)備和模擬器進(jìn)行編譯寄啼,最后找到相關(guān)的.a進(jìn)行合包逮光,使用lipo -create 真機(jī)庫.a的路徑 模擬器庫.a的的路徑 -output 合成庫的名字.a

(詳情可以參考http://blog.csdn.net/lizhongfu2013/article/details/12648633)

這樣就制作了一個(gè)通用的靜態(tài)庫.a

參考鏈接:

https://blog.csdn.net/lizhongfu2013/article/details/42387311

http://www.cocoachina.com/cms/wap.php?action=article&id=21852

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市墩划,隨后出現(xiàn)的幾起案子涕刚,更是在濱河造成了極大的恐慌,老刑警劉巖乙帮,帶你破解...
    沈念sama閱讀 216,997評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件杜漠,死亡現(xiàn)場離奇詭異,居然都是意外死亡察净,警方通過查閱死者的電腦和手機(jī)驾茴,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,603評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來氢卡,“玉大人锈至,你說我怎么就攤上這事∫肭兀” “怎么了峡捡?”我有些...
    開封第一講書人閱讀 163,359評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長筑悴。 經(jīng)常有香客問我们拙,道長,這世上最難降的妖魔是什么阁吝? 我笑而不...
    開封第一講書人閱讀 58,309評論 1 292
  • 正文 為了忘掉前任砚婆,我火速辦了婚禮,結(jié)果婚禮上突勇,老公的妹妹穿的比我還像新娘射沟。我一直安慰自己,他們只是感情好与境,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,346評論 6 390
  • 文/花漫 我一把揭開白布验夯。 她就那樣靜靜地躺著,像睡著了一般摔刁。 火紅的嫁衣襯著肌膚如雪挥转。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,258評論 1 300
  • 那天共屈,我揣著相機(jī)與錄音绑谣,去河邊找鬼。 笑死拗引,一個(gè)胖子當(dāng)著我的面吹牛借宵,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播矾削,決...
    沈念sama閱讀 40,122評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼壤玫,長吁一口氣:“原來是場噩夢啊……” “哼豁护!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起欲间,我...
    開封第一講書人閱讀 38,970評論 0 275
  • 序言:老撾萬榮一對情侶失蹤楚里,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后猎贴,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體班缎,經(jīng)...
    沈念sama閱讀 45,403評論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,596評論 3 334
  • 正文 我和宋清朗相戀三年她渴,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了达址。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,769評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡趁耗,死狀恐怖苏携,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情对粪,我是刑警寧澤,帶...
    沈念sama閱讀 35,464評論 5 344
  • 正文 年R本政府宣布装蓬,位于F島的核電站著拭,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏牍帚。R本人自食惡果不足惜儡遮,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,075評論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望暗赶。 院中可真熱鬧鄙币,春花似錦、人聲如沸蹂随。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,705評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽岳锁。三九已至绩衷,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間激率,已是汗流浹背咳燕。 一陣腳步聲響...
    開封第一講書人閱讀 32,848評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留乒躺,地道東北人招盲。 一個(gè)月前我還...
    沈念sama閱讀 47,831評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像嘉冒,于是被迫代替她去往敵國和親曹货。 傳聞我的和親對象是個(gè)殘疾皇子咆繁,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,678評論 2 354