iOS基礎知識之@property 和 Ivar 的區別_IOS

來源:互聯網
上載者:User

@property

屬性其實是對成員變數的一種封裝。我們先大概這樣理解:

@property = Ivar + setter + getter

Ivar

Ivar可以理解為類中的一個變數,主要作用是用來儲存資料的。

我們不妨來看個例子,通過下邊的例子能夠很清楚的解釋這兩個東東:

我們建立一個Person類

@interface Person : NSObject{NSString *name0;}@property(nonatomic,copy)NSString *name1;@end@implementation Person- (instancetype)init {if (self = [super init]) {}return self;}@end

在這個Person中name0就是成員變數,name1就是屬性。

我們建立一個Person:

Person *p= [[Person alloc] init];p.name1 = @"abc";NSLog(@"%@",p.name1);

我們會發現,我在Person類外邊是不能訪問name0的,這說明了什嗎?這說明成員變數<font color=red>name0</font>只能在它自己的類的內部被訪問。

因此,我們推斷出,@property其實也帶有介面屬性,也就是能夠被外部對象訪問。

p.name1 = @"abc";

這行代碼其實是調用了Person中name1的setter方法。

NSLog(@"%@",p.name1);

這行代碼其實是調用了Person中name1的getter方法。

再說說setter和getter方法。大家應該都知道oc中有著嚴格的命名規範,拿這個例子來說,根據name1自動產生了

- (void)setName1:(NSString *)name1{}- (NSString *)name1

注意:這裡並不討論MRC的情況,一切解釋的前提都是在ARC下。

@synthesize

這個關鍵字用來指定成員變數

我們在Person的實現中,把代碼改成這樣:

@implementation Person@synthesize name1 = _name2;- (instancetype)init {if (self = [super init]) {_name2 = @"aaa";}return self;}@end

這樣我們就指定了name1的成員變數為_name2了,我們在Person的初始化init方法中根本打不出_name1這個屬性。

Person *p= [[Person alloc] init];// p.name1 = @"abc";NSLog(@"%@",p.name1);

我們注釋掉賦值的那一行,可以看到列印結果為:aaa。

以上所述是小編給大家介紹的iOS基礎知識之@property 和 Ivar 的區別,希望對大家有所協助,如果大家有任何疑問請給我留言,小編會及時回複大家的。在此也非常感謝大家對雲棲社區網站的支援!

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.