pragma mark property增强
pragma mark 概念
pragma mark 代码
#import <Foundation/Foundation.h>
#pragma mark 类
#import "Person.h"
#pragma mark main函数
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;
}
Person.h //人类
#import <Foundation/Foundation.h>
@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文件中生成的
*/
//#warning Xcode4.4之后 @property 做的事情
/*
- (void)setAge:(int)age;
- (int)age;
*/
// age ? _age?
@property int age;
@end
IPhone.m
#import "Person.h"
@implementation Person
#warning Xcode4.4之后 @property 做的事情
/*
- (void)setAge:(int)age
{
_age = age;
}
- (int)age
{
return _age;
}
*/
#warning 重新写setter和getter方法 (对数据进行过滤)
/*
如果重写了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