成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Xcode ARC詳解全攻略

移動開發 iOS
ios5中,有個很吸引眼球的特性就是“Automatic Reference Counting”,簡單來說就是內存自動回收,看起來似乎是平時開發中遇到的各種內存問題的福音,仔細了解了一下,似乎沒有那么美好:1、需要iOS5才支持;2、很多引用的類庫暫時還不支持.麻煩的是對大多數第三方庫需要加禁用arc的編譯flag,因為大多都因為兼容性還在使用手動內存管理。
iOS上內存管理一直讓人很頭疼.

手動管理內存經常忘掉release或autorelease,或者因為release多了、retain少了導致空指針引用程序崩潰,還要經常按COMMAND+SHIFT+B,豈止頭疼,簡直蛋疼有木有。

雖然objective-c 2.0支持垃圾收集器(Garbage Collection,簡稱GC),但是垃圾收集器只能在MAC程序上開啟,ios上沒辦法用。就算在MAC應用程序上可以用,GC也會有性能上的損耗。

現在LLVM3.0多了一個給力的新東西,叫Automatic Reference Counting。開啟這個選項之后,LLVM會在編譯階段自動幫開發者完成“手動”的內存管理。同時,所有代碼中的retain,release和 autorelease會被標記成錯誤,也就是說,我們完全不需要用以前頭蛋俱疼的方式管理內存了。

ARC不僅可以修復錯誤,還能增強性能。根據WWDC 2011大會的介紹,retain/release快了2.5倍,@autoreleasepool快了6倍,objc_msgSend快了33%。

一、舊工程開啟ARC的方法

xCode4.2中已經自帶了LLVM3.0,在用新的模板建立工程時,編譯器默認選擇LLVM3.0,并且開啟ARC。如圖。

xCode4.2 也為ARC提供了自動轉換工具。首先將工程的編譯器切換為LLVM3.0,然后在菜單里選擇Edit—-Refactor—-Convert to Objective-C ARC…。LLVM會將不能轉換的部分標記為錯誤,要求我們手動修改。一般NSAutoReleasePool不能自動轉換,要手動轉為 @autoreleasepool。CF框架的方法也不能自動轉換,而release、retain和autorelease是可以自動轉換的。我們將不 能自動轉換的錯誤手動修改好后,編輯器將完成自動轉換。

對 于可能出現的錯誤,WWDC 2011的視頻中給出了一些例子。比如用static count來處理singletons pattern;用weak來申明delegate pattern;用dispatch_once來保證多線程的安全;在case關鍵字后面加上大括號{..}來限制case里面申明變量的作用范圍等等。

二、開啟ARC后需要遵循的原則

1、不能調用retain/release/autorelease,這些由編譯器來完成。

2、結構內不能有對象指針,如果結構中包含,則需要以類代替結構。

3、不能使用id<–>void *的類型轉換,因為編譯器不知道這個void *是否需要retained。

4、不能使用NSAutoreleasedPool,要用@autoreleasepool {……}來代替。

三、ARC中引入的四個新的關鍵字

1、Strong Reference,強引用。默認類型,不加任何關鍵字(也可以寫成__strong)。相當于之前代碼中的retain屬性。

2、Autoreleasing Reference,自動釋放引用。通常出現在例如系統error處理函數中(關鍵字__autoreleasing),描述out-parameters用,只保存在棧中,不太常用。

3、Unsafe Reference,不安全引用。類似于之前代碼中的assign屬性,不分配內存(關鍵字__unsafe_unretained),相當于起了個別名。

4、Weak Reference,弱引用。前面提到過,不增加計數,當對象開始釋放時,立刻設置成nil。

四、ARC中循環引用造成內存泄露的原因與解決辦法

ARC通過記錄指向某對象的指針數量來判斷該對象是否應該被釋放(0代表可以釋放)。因而如果出現循環引用,就會出現內存泄露。如下圖所示。

 取消3->2的引用   導致泄露。

ARC的解決辦法也和簡單,使用弱引用(weak reference)。弱引用的申明方式舉例如下:
id __weak P;
@property (weak) NSVIew *V;
還是以上面的例子做對比,結果如下:

 弱引用不增加計數, 從而消除leak。

五、Instruments的Leaks的新功能

這張圖里面就標識出了整個leak cycle的全景圖。點擊cycle graph中的紅色箭頭,就會自動跳到code中對應的變量聲明處,根據情況加上weak關鍵字就解決leak了。
在新舊技術更替的更年期應注意:現在ARC還under NDA,沒有任何開源框架可以公開支持ARC的,如果想使用此特性,在選取開源框架時應該盡量選擇使用CF庫較少的框架,否則手動爆開源框架的菊花會很痛苦。


一篇深入討論 ARC的文章

http://longweekendmobile.com/2011/09/07/objc-automatic-reference-counting-in-xcode-explained/

責任編輯:閆佳明 來源: blog.163
相關推薦

2011-10-31 14:44:49

2010-04-23 14:04:23

Oracle日期操作

2024-05-07 09:01:21

Queue 模塊Python線程安全隊列

2013-06-08 11:13:00

Android開發XML解析

2009-02-20 11:43:22

UNIXfish全攻略

2014-03-19 17:22:33

2009-12-14 14:32:38

動態路由配置

2009-10-19 15:20:01

家庭綜合布線

2009-10-12 15:06:59

2015-03-04 13:53:33

MySQL數據庫優化SQL優化

2009-07-04 11:26:12

unix應急安全攻略

2022-10-21 11:30:42

用戶生命周期分析

2020-12-28 10:50:09

Linux環境變量命令

2010-10-11 13:54:03

Windows Ser

2009-12-17 16:15:00

CCNA640-810

2009-11-10 12:08:15

2020-11-23 15:21:12

Linux環境變量

2009-07-17 17:43:49

Jruby開發Web

2019-06-27 11:47:21

Wordpress容器化HTTPS

2009-02-12 10:12:00

NAT配置
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲精品18 | 欧美一区二区三区在线播放 | 成人精品视频在线观看 | 精品视频在线播放 | 欧美成人一级视频 | 久色网 | 理论片免费在线观看 | 免费毛片网站 | 亚洲一区 中文字幕 | 亚洲视频在线观看免费 | 成人精品一区二区 | 欧美日高清 | 亚洲精品电影 | 一区二区在线免费观看 | 在线视频一区二区三区 | 日日操操 | 超碰成人免费 | 亚洲综合五月天婷婷 | 成人亚洲| 久久国产精品一区二区三区 | 4hu最新网址 | 日韩一区二区在线视频 | 亚洲精品电影在线观看 | 精品福利在线 | 精品欧美乱码久久久久久 | 黄网站在线播放 | 一级国产精品一级国产精品片 | 欧美性网 | 一区二区三区视频在线观看 | 亚洲精品久久久久久久久久久 | 综合精品久久久 | 国产精品69毛片高清亚洲 | 久久综合久久自在自线精品自 | 伊人狠狠| 久久久久国产精品一区二区 | 国产精品一区二区在线 | 91午夜在线 | 尤物在线视频 | 人人鲁人人莫人人爱精品 | 亚洲一区二区在线 | 99re国产视频 |