我們知道在Objective-C中,使用@property配合@synthesize可以讓編譯器自動(dòng)實(shí)現(xiàn)getter/setter方法,使用的時(shí)候也很方便,可以直接使用對(duì)象.屬性的方法調(diào)用。
NSString* name;
NSUInteger age;
@property(nonatomic,copy)NSString* name;
@property(assign)NSUInteger age;
@synthesize name;
@synthesize age;
那如果我們想要對(duì)象.方法的方式來調(diào)用一個(gè)方法并獲取到方法的返回值,那就需要使用@property配合@dynamic了。
@property(readonly)NSString* firstArrayValue;
@dynamic firstArrayValue;
- (NSString*)firstArrayValue
{
return [_array objectAtIndex:0];
}
這樣就可以使用對(duì)象.firstArrayValue來獲取到_array數(shù)組中的第一個(gè)值了,很顯然,這種方法并不適用于需要傳遞參數(shù)的方法。
其實(shí)使用@dynamic關(guān)鍵字是告訴編譯器由我們自己來實(shí)現(xiàn)訪問方法。
如果使用的是@synthesize,那么這個(gè)工作編譯器就會(huì)幫你實(shí)現(xiàn)了。 這時(shí)候你也可以自己實(shí)現(xiàn)此屬性的Accessor,系統(tǒng)會(huì)調(diào)用你的實(shí)現(xiàn)代替系統(tǒng)的實(shí)現(xiàn)。雖然使用@property減少了代碼,但是在我們的代碼中,為了統(tǒng)一,最好還是使用[obj attribute]的方式來調(diào)用Accessors,不要一會(huì)使用obj.attribute,一會(huì)使用[obj attribute],讓代碼不夠統(tǒng)一。
說明:代碼只為示例代碼,實(shí)際使用時(shí)每句代碼要放到相應(yīng)位置的。
===== 最后轉(zhuǎn)載下關(guān)于@property(*)括號(hào)中的屬性內(nèi)容介紹 =====
readonly
此標(biāo)記說明屬性是只讀的,默認(rèn)的標(biāo)記是讀寫,如果你指定了只讀,在@implementation中只需要一個(gè)讀取器。或者如果你使用@synthesize關(guān)鍵字,也是有讀取器方法被解析。而且如果你試圖使用點(diǎn)操作符為屬性賦值,你將得到一個(gè)編譯錯(cuò)誤。
readwrite
此標(biāo)記說明屬性會(huì)被當(dāng)成讀寫的,這也是默認(rèn)屬性。設(shè)置器和讀取器都需要在@implementation中實(shí)現(xiàn)。如果使用@synthesize關(guān)鍵字,讀取器和設(shè)置器都會(huì)被解析。
assign
此標(biāo)記說明設(shè)置器直接進(jìn)行賦值,這也是默認(rèn)值。在使用垃圾收集的應(yīng)用程序中,如果你要一個(gè)屬性使用assign,且這個(gè)類符合NSCopying協(xié)議,你就要明確指出這個(gè)標(biāo)記,而不是簡(jiǎn)單地使用默認(rèn)值,否則的話,你將得到一個(gè)編譯警告。這再次向編譯器說明你確實(shí)需要賦值,即使它是可拷貝的。
retain
指定retain會(huì)在賦值時(shí)喚醒傳入值的retain消息。此屬性只能用于Objective-C對(duì)象類型,而不能用于Core Foundation對(duì)象。(原因很明顯,retain會(huì)增加對(duì)象的引用計(jì)數(shù),而基本數(shù)據(jù)類型或者Core Foundation對(duì)象都沒有引用計(jì)數(shù)——譯者注)。
copy
它指出,在賦值時(shí)使用傳入值的一份拷貝。拷貝工作由copy方法執(zhí)行,此屬性只對(duì)那些實(shí)行了NSCopying協(xié)議的對(duì)象類型有效。更深入的討論,請(qǐng)參考“復(fù)制”部分。
nonatomic
指出訪問器不是原子操作,而默認(rèn)地,訪問器是原子操作。這也就是說,在多線程環(huán)境下,解析的訪問器提供一個(gè)對(duì)屬性的安全訪問,從獲取器得到的返回值或者通過設(shè)置器設(shè)置的值可以一次完成,即便是別的線程也正在對(duì)其進(jìn)行訪問。如果你不指定nonatomic,在自己管理內(nèi)存的環(huán)境中,解析的訪問器保留并自動(dòng)釋放返回的值,如果指定了nonatomic,那么訪問器只是簡(jiǎn)單地返回這個(gè)值。
From: http://www.cnblogs.com/kaixuan/archive/2011/03/02/1969072.html
#import <Foundation/Foundation.h>
@interface Employee : NSObject {
NSString *firstName;
NSString *lastName;
}
@property (retain, readwrite, nonatomic) NSString *firstName;
@property (retain, readwrite, nonatomic) NSString *lastName;
@end
//
// Employee.m
// PropertyTest
//
// Created by Biao Huang on 12/15/11.
// Copyright (c) 2011 __MyCompanyName__. All rights reserved.
//
#import "Employee.h"
@implementation Employee
@dynamic firstName;
@synthesize lastName;
- (id)init {
self = [super self];
if (self) {
// 測(cè)試代碼,三種形式都可以使用
self.firstName = @"biao";
NSLog(@"%@", firstName);
NSLog(@"%@", [self firstName]);
NSLog(@"%@", self.firstName);
}
return self;
}
- (void)setFirstName:(NSString *)newFirstName {
NSLog(@"[Employee setFirstName:]");
[newFirstName retain];
[firstName release];
firstName = newFirstName;
}
- (NSString *)firstName {
NSLog(@"[Employee firstName]");
return firstName;
}
@end