根據(jù)文檔翻譯的總結(jié): 在高級(jí)別上,下面的步驟創(chuàng)建一個(gè)應(yīng)用程序,目標(biāo)32位和64位運(yùn)行時(shí)環(huán)境:
1. 安裝最新的Xcode。
2.打開(kāi)你的項(xiàng)目笔宿。Xcode提示您現(xiàn)代化項(xiàng)目±庥眨現(xiàn)代化的項(xiàng)目添加新警告和錯(cuò)誤64位的重要當(dāng)編譯你的應(yīng)用程序。(個(gè)人覺(jué)得就是編譯程序炬灭,看編譯警告)
3. 更新您的項(xiàng)目設(shè)置支持iOS 5.1.1或更高版本靡菇。你不能建立一個(gè)64位的項(xiàng)目如果目標(biāo)一個(gè)iOS版本早于iOS 5.1。
4. 把架構(gòu)構(gòu)建設(shè)置在您的項(xiàng)目中“標(biāo)準(zhǔn)體系結(jié)構(gòu)(包括64位)鼻吮∮具耄”(在“Build Setting”中將“Architectures”改成“Standard Architectures (including 64-bit))
5.更新您的應(yīng)用程序支持64位運(yùn)行時(shí)環(huán)境。新編譯器警告和錯(cuò)誤將有助于指導(dǎo)您完成這一過(guò)程拓哺。然而,編譯器并不為你做所有的工作,使用本文檔中的信息來(lái)幫助指導(dǎo)您完成調(diào)查自己的代碼脖母。
6.實(shí)際的64位硬件上測(cè)試應(yīng)用程序。iOS模擬器還可以在開(kāi)發(fā)過(guò)程中是有用的,但有些變化,比如函數(shù)的調(diào)用約定,是可見(jiàn)的只有當(dāng)你的應(yīng)用程序在設(shè)備上運(yùn)行烤礁。
關(guān)于Xcode “Build Setting”中的Architectures參數(shù)問(wèn)題
1.Architectures:你想支持的指令集肥照。(支持指令集是通過(guò)編譯生成對(duì)應(yīng)的二進(jìn)制數(shù)據(jù)包實(shí)現(xiàn)的,如果支持的指令集數(shù)目有多個(gè)鲤脏,就會(huì)編譯出包含多個(gè)指令集代碼的數(shù)據(jù)包吕朵,造成最終編譯的包很大。)
2.Valid architectures:即將編譯的指令集硫嘶。(Valid architectures和Architecture兩個(gè)集合的交集為最終編譯生成的版本)
3.Build Active Architecture Only:是否只編譯當(dāng)前設(shè)備適用的指令集(如果這個(gè)參數(shù)設(shè)為YES梧税,使用iPhone 6調(diào)試,那么最終生成的一個(gè)支持ARM64指令集的Binary哮塞。一般在DEBUG模式下設(shè)為YES斥铺,RELEASE設(shè)為NO)
(以下文字說(shuō)明:總結(jié)起來(lái)就是說(shuō)32位中和64位中的數(shù)據(jù)存儲(chǔ)類(lèi)型發(fā)生了改變,會(huì)導(dǎo)致存儲(chǔ)的數(shù)據(jù)變化晾蜘,所以以后在新開(kāi)發(fā)的代碼中需要過(guò)濾c語(yǔ)言的基礎(chǔ)類(lèi)型,推崇使用oc數(shù)據(jù)存儲(chǔ)的類(lèi)型)
具體做法:
int -> NSInteger
unsigned -> NSUInteger
float -> CGFloat
動(dòng)畫(huà)時(shí)間-> NSTimeInterval
例子:NSInteger i = 10086;
NSString *string = @(i).stringValue;
開(kāi)發(fā)人員根據(jù)以下要點(diǎn)來(lái)檢查原來(lái)的32位代碼就可以將應(yīng)用移植到64位系統(tǒng)上了:1.不要將長(zhǎng)整型數(shù)據(jù)(long)賦予整型(int)這種代碼在32位系統(tǒng)上沒(méi)有問(wèn)題肆饶,因?yàn)樵?2位系統(tǒng)中l(wèi)ong和int的長(zhǎng)度是一樣的驯镊,不過(guò)在64位系統(tǒng)中就有可能出問(wèn)題,因?yàn)?4位系統(tǒng)中l(wèi)ong比int長(zhǎng)板惑,將long值賦予int將導(dǎo)致數(shù)據(jù)丟失。2.不要將指針類(lèi)型(Pointer)賦予整型(int)為了方便地址計(jì)算洽胶,有時(shí)程序員會(huì)將指針類(lèi)型賦予整型裆馒,這種代碼在32位系統(tǒng)上沒(méi)有問(wèn)題,因?yàn)樵?2位系統(tǒng)中Pointer和int的長(zhǎng)度是一樣的翔横,不過(guò)在64位系統(tǒng)中就會(huì)有問(wèn)題梗搅,因?yàn)?4位系統(tǒng)中Pointer比int長(zhǎng),將Pointer值賦予int將導(dǎo)致地址數(shù)據(jù)丟失蟀俊,最終導(dǎo)致嚴(yán)重問(wèn)題订雾。3.留意那些和數(shù)位相關(guān)的數(shù)值計(jì)算比如掩碼技術(shù),如果使用一個(gè)long類(lèi)型的掩碼烫映,轉(zhuǎn)到64位系統(tǒng)后高位都是0,計(jì)算出來(lái)的結(jié)果可能不符合預(yù)期锭沟。還有無(wú)符號(hào)整數(shù)和有符號(hào)整數(shù)的混用等识补。4.留意對(duì)齊方式帶來(lái)的變化如果在32位系統(tǒng)上定義一個(gè)結(jié)構(gòu)包含兩個(gè)long類(lèi)型,第二個(gè)long數(shù)值的偏移地址是4祝辣,可以通過(guò)結(jié)構(gòu)地址+4的方式獲取切油,但是在64位系統(tǒng)上就不行了,因?yàn)樵?4位系統(tǒng)中第二個(gè)long數(shù)值的偏移地址是8孕荠。5.充分考慮在32位應(yīng)用和64位應(yīng)用之間的數(shù)據(jù)交換因?yàn)橛脩魰?huì)通過(guò)網(wǎng)絡(luò)交換數(shù)據(jù),同時(shí)用戶保存的數(shù)據(jù)也可能通過(guò)備份等方式在32位系統(tǒng)和64位系統(tǒng)之間切換稚伍,所以應(yīng)用在保存和發(fā)送流數(shù)據(jù)的時(shí)候一定要考慮充分。比如數(shù)據(jù)在32位系統(tǒng)中保存熙涤,在64位系統(tǒng)中能否正常打開(kāi)困檩,或者反過(guò)來(lái)那槽,在64位系統(tǒng)中保存,在32位系統(tǒng)中打開(kāi)是否正常骚灸。6.重寫(xiě)所有匯編代碼這點(diǎn)無(wú)需說(shuō)明,如果你在代碼中嵌入了匯編代碼义郑,你需要參考64位系統(tǒng)的指令集重寫(xiě)匯編代碼丈钙。7.不要將可變參數(shù)的過(guò)程強(qiáng)制轉(zhuǎn)換為定參過(guò)程,也不要將定參過(guò)程強(qiáng)制轉(zhuǎn)換為可變參數(shù)的過(guò)程這時(shí)因?yàn)?2位系統(tǒng)和64位系統(tǒng)對(duì)于這兩種過(guò)程調(diào)用方式的處理方法不同劫笙。