萬盛學電腦網

 萬盛學電腦網 >> 網絡編程 >> ios >> iOS開發:strong、weak等詳解

iOS開發:strong、weak等詳解

   現在我們看看iOS5中新的關鍵字strong, weak, unsafe_unretained. 可以與以前的關鍵字對應學習strong與retain類似,weak與unsafe_unretained功能差不多(有點區別,等下會介紹,這兩個新 關鍵字與assign類似)。在iOS5中用這些新的關鍵字,就可以不用手動管理內存了,從java等其它語言轉過來的程序員非常受用。

  strong關鍵字與retain關似,用了它,引用計數自動+1,用實例更能說明一切

  @property (nonatomic, strong) NSString *string1;

  @property (nonatomic, strong) NSString *string2;

  有這樣兩個屬性

  @synthesize string1;

  @synthesize string2;

  猜一下下面代碼將輸出什麼結果?

  self.string1 = @"String 1";

  [self.string2 = self.string1;

  [self.string1 = nil;

  [NSLog(@"String 2 = %@", self.string2);

  結果是:String 2 = String 1

  由於string2是strong定義的屬性,所以引用計數+1,使得它們所指向的值都是@"String 1", 如果你對retain熟悉的話,這理解並不難。

  接著我們來看weak關鍵字:

  如果這樣聲明兩個屬性:

  @property (nonatomic, strong) NSString *string1;

  @property (nonatomic, weak) NSString *string2;

  並定義

  @synthesize string1;

  @synthesize string2;

  再來猜一下,下面輸出是什麼?

  self.string1 = [[NSString alloc] initWithUTF8String:"string 1"];

  elf.string2 = self.string1;

  self.string1 = nil;

  NSLog(@"String 2 = %@", self.string2);

  結果是:String 2 = null

  分析一下,由於 self.string1與self.string2指向同一地址,且string2沒有retain內存地址,而self.string1=nil釋放 了內存,所以string1為nil。聲明為weak的指針,指針指向的地址一旦被釋放,這些指針都將被賦值為nil。這樣的好處能有效的防止野指針。在 c/c++開發過程中,為何大牛都說指針的空間釋放了後,都要將指針賦為NULL. 在這兒用weak關鍵字幫我們做了這一步。

  接著我們來看unsafe_unretained

  從名字可以看出,unretained且unsafe,由於是unretained所以與weak有點類似,但是它是unsafe的,什麼是unsafe的呢,下面看實例。

  如果這樣聲明兩個屬性:

  並定義

  @property (nonatomic, strong) NSString *string1;

  @property (nonatomic, unsafe_unretained) NSString *string2;

  再來猜一下,下面的代碼會有什麼結果?

  self.string1 = [[NSString alloc] initWithUTF8String:"string 1"];

  self.string2 = self.string1;

  self.string1 = nil;

  NSLog(@"String 2 = %@", self.string2);

  請注意,在此我並沒有叫你猜會有什麼輸出,因為根本不會有輸出,你的程序會crash掉。 原因是什麼,其實 就是野指針造成的,所以野指針是可怕的。為何會造成野指針呢?同於用unsafe_unretained聲明的指針,由於 self.string1=nil已將內存釋放掉了,但是string2並不知道已被釋放了,所以是野指針。然後訪問野指針的內存就造成crash. 所以盡量少用unsafe_unretained關鍵字。

copyright © 萬盛學電腦網 all rights reserved