OC语言day04-04property增强

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容