//// Person.h#import@interface Person : NSObject/*{ @public int _age; int age;} *//* 从Xcode4.4以后apple对@property进行了一个增强, 以后只要利用一个@property就可以同时生成setter/getter方法的声明和实现 没有告诉@property要将传入的参数赋值给谁, 默认@property会将传入的属性赋值给_开头的成员变量 @property有一个弊端: 它只会生成最简单的getter/setter方法的声明和实现, 并不会对传入的数据进行过滤 如果想对传入的数据进行过滤, 那么我们就必须重写getter/setter方法 如果不想对传入的数据进行过滤, 仅仅是提供一个方法给外界操作成员变量, 那么就可以使用@property 如果利用@property来生成getter/setter方法, 那么我们可以不写成员变量, 系统会自动给我们生成一个_开头的成员变量 注意: @property自动帮我们生成的成员变量是一个私有的成员变量, 也就是说是在.m文件中生成的, 而不是在.h文件中生成的 */// age? _age; _age/* - (void)setAge:(int)age; - (int)age; */@property int age; //就可以使用[p setAge:-88],[p age],因为自动生成了这些get,set方法。@end
// Person.m#import "Person.h"@implementation Person/* - (void)setAge:(int)age { _age = age; } - (int)age { return _age; } */// 如果重写了setter方法, 那么property就只会生成getter方法// 如果重写了getter方法, 那么property就只会生成setter方法// 如果同时重写了getter/setter方法, 那么property就不会自动帮我们生成私有的成员变量,就要自己重新定义变量。/*- (void)setAge:(int)age{ if (age < 0) { age = 0; } _age = age;}- (int)age{ return _age;}*/@end
//// main.m// Property增强#import#import "Person.h"int main(int argc, const char * argv[]) { Person *p = [Person new]; [p setAge:-88]; NSLog(@"age = %i", [p age]); NSLog(@"_age = %i, age = %i", p->_age, p->age);//私有的 return 0;}