iOS11 誕生
蘋果在06-06凌晨正式發(fā)布了iOS 11系統(tǒng),在UI風格编饺、系統(tǒng)性能壁酬、功能上都進行了提升,但究竟哪些設備支持升級iOS 11?你手中的iPhone或者iPad究竟是否在適配之列呢?看看蘋果官方給出的答案酣栈。
此次iOS 11的更新拋棄了iPhone 5、iPhone 5c汹押、iPad 4三款設備矿筝,宣告了32位設備的正式淘汰,這些設備用戶是時候換機了棚贾。
處理器 32bit 與 64bit 哪些機型
1.蘋果A7處理器之后都64位窖维,以前處理器是32位。
2.iPhone5S和ipad air之后的機型都是64位妙痹,以前的版本都是32位的老機型铸史。
iPhone 64bit歷史
2013年9月,蘋果發(fā)布了 iPhone 5s怯伊,這也是首款搭載 64 位處理器的 iPhone琳轿,同時開始支持 64 位應用。自2015年2月之后耿芹,蘋果要求開發(fā)者必須遞交 64 位新應用和應用升級崭篡。
接下來,iOS11將徹底淘汰32位應用猩系,全面進入64位時代
- 數(shù)據(jù)類型的變化
指令級并行性(Instruction-Level Parallelism,ILP)
解決兼容 ??
看看NSInteger
在xcode中NSObjCRuntime.h
里的定義
#if __LP64__ || (TARGET_OS_EMBEDDED && !TARGET_OS_IPHONE) || TARGET_OS_WIN32 || NS_BUILD_32_LIKE_64
typedef long NSInteger;
typedef unsigned long NSUInteger;
#else
typedef int NSInteger;
typedef unsigned int NSUInteger;
#endif
數(shù)據(jù)類型里面媚送,NSInteger在 32ILP 時等同于int
(4bytes)中燥,在64ILP 時等同于long
(8bytes)寇甸,而這個數(shù)據(jù)結構使用很廣,很多不規(guī)范的時候會直接和int替換使用,在32ILP是毫無問題拿霉,但在64ILP時吟秩,這就是隱患了。CGFloat
也有同樣的問題绽淘,所以代碼的檢查修改必須仔細涵防。
CGFloat
定義如下
/* Definition of `CGFLOAT_TYPE', `CGFLOAT_IS_DOUBLE', `CGFLOAT_MIN', and
`CGFLOAT_MAX'. */
#if defined(__LP64__) && __LP64__
# define CGFLOAT_TYPE double
# define CGFLOAT_IS_DOUBLE 1
# define CGFLOAT_MIN DBL_MIN
# define CGFLOAT_MAX DBL_MAX
#else
# define CGFLOAT_TYPE float
# define CGFLOAT_IS_DOUBLE 0
# define CGFLOAT_MIN FLT_MIN
# define CGFLOAT_MAX FLT_MAX
#endif
/* Definition of the `CGFloat' type and `CGFLOAT_DEFINED'. */
typedef CGFLOAT_TYPE CGFloat;
so ~ ,一般數(shù)字串(時間戳, 用戶id), 咱們使用 long long
接收就行, 無論32ILP還是64ILP ,都是分配8bytes;
帶小數(shù)的, 就不用CGFloat
了, 用C語言的float
/ double
就行, 在 32ILP/64ILP 都一樣
另外,sunny大神的博文64-bit Tips