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 = @"String 1";
self.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關鍵字幫我們做了這一步。