iOS ARC基本原理

1、ARC基本簡介性能

  • ARC:Automatic Reference Counting 自動引用
  • 徹底消除了手動管理內存的煩瑣,編譯器會自動在適當的地方插入適當的retain、release、autorelease語句。開發者再也不須要擔憂內存管理,由於編譯器已經處理了一切
  • ARC是自iOS 5以後增長的新特性:ARC 是編譯器特性,而不是 iOS 運行時特性,它也不是相似於其它語言中的垃圾收集器好比,Java中的垃圾回收是在運行時自動檢測對象有沒有用若是沒用則進行回收
  • ARC 和手動內存管理性能是同樣的,有時還能更加快速,由於編譯器還能夠執行某些優化 
  • Xcode5以後新建程序默認遵循ARC機制

2、ARC基本原理優化

一、規則spa

ARC 的規則很是簡單:只要還有一個強指針變量指向對象,對象就會保持在內存中指針

二、強指針和弱指針code

  • 默認全部實例變量和局部變量都是Strong指針
  • 弱指針指向的對象被回收後,弱指針會自動變爲nil指針,不會引起野指針錯誤

3、使用注意對象

  • 不能調用release、retain、autorelease、retainCount
  • 能夠重寫dealloc,可是不能調用[super dealloc]
  • @property : 想長期擁有某個對象,應該用strong,其餘對象用weak
  • 其餘基本數據類型依然用assign
  • 兩端互相引用時,一端用strong、一端用weak

ARC規則:類對象一旦沒有強指針指向它則被銷燬blog

驗證代碼:內存

/****************************** Person.h文件 ***********************************/
#import <Foundation/Foundation.h>
@interface Person : NSObject
@end

/****************************** Person.m文件 ***********************************/ #import "Person.h" @implementation Person - (void)dealloc { NSLog(@"Person對象被銷燬"); } @end

/****************************** main.m文件 ***********************************/ #import "Person.h" #import <Foundation/Foundation.h> int main(int argc, const char * argv[]) { Person *p = [[Person alloc] init]; p = [[Person alloc] init];  // 這行代碼執行完說明Person類對象的指針p 指向了另外一個類對象 那麼上面的類對象Person被銷燬 執行一次dealloc方法
  return 0; 
}

// main方法執行完畢 局部變量p被回收那麼第二個Person類對象也被回收再執行一次dealloc方法

// 再一次說明一個對象若是沒有一個強指針指向它的話,對象就會被回收

 修改上面的main方法,驗證強指針和弱指針:開發

    __strong Person *p1 = [[Person alloc] init]; // 默認都是強指針所以不須要寫 __strong
    
    __weak Person *p2 = p1; // 將強指針指的內存地址 賦值給弱指針 那麼強弱指針指向同一塊內存地址
    
    p1 = nil; // 清空強指針 這行代碼執行完畢就調用了 - dealloc方法 說明Person類對象被銷燬了
    
    p2 = nil; // 清空弱指針 強指針清空後Person類對象已經被銷燬了 並且弱指針系統會自動清空 那麼就不會執行 - dealloc方法了 所以這行代碼能夠不寫
    
    return 0;
相關文章
相關標籤/搜索