你好,歡迎來到IOS教程網

 Ios教程網 >> IOS基礎知識 >> IOS基礎知識 >> iOS基礎知識之@property 和 Ivar 的區別

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

編輯:IOS基礎知識

@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 的區別,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

  1. 上一頁:
  2. 下一頁:
蘋果刷機越獄教程| IOS教程問題解答| IOS技巧綜合| IOS7技巧| IOS8教程
Copyright © Ios教程網 All Rights Reserved