第04天OC语言(04):property增强

  • 不要等到明天,明天太遥远,今天就行动。

#####须读:看完该文章你能做什么?

你能知道property内部做了什么事情 1> 生成setter方法、getter方法 2> 在内部生成一个私有的变量(_成员变量) 3> 和@synthesize age有区别 ,@synthesize age;直接赋值给age

#####学习前:你必须会什么?

了解什么是封装。


#####一、本章笔记

 一、
     从Xcode4.4以后 Apple 对 @property进行一个增强,以后只要利用一个 @property 就可以同时生成 setter 、 getter 方法的声明 和实现
     没有告诉 @property 要将传入的参数赋值给谁,默认 @property 会将传入的属性 赋值给 _开头的成员变量
     
     @property 有一个弊端: 他只会生成 最简单的getter\setter方法的声明和实现,并不会对传入的数据进行过滤
     如果想对传入的数据进行过滤,那么我们就必须重写 setter\getter方法
     如果不想对传入的数据进行过滤,仅仅是提供一个方法给外界操作变量,那么就可以使用
     
     如果利用 @property来生成 getter/setter方法,那么我们可以不写成员变量,系统会自动给我们生成一个 _开头的成员变量
     注意: @property 自动带我们生成的成员变量 是 一个私有的成员变量, 也就是说是.m文件中生成的,而不是在.h文件中生成的
 二、
     如果重写了setter方法,那么property就只会生成getter方法
     如果重写了getter方法,那么property就只会生成setter方法
     如果同时 重写了getter/setter方法,那么@property就不会自动 带我们生成私有的成员变量
 三、注意:
     系统 和 @synthesize 有点区别
     系统直接赋值给 _age
     而使用 @synthesize age; 系统 则会赋值给 age;

#####二、code ######main.m

#pragma mark 04-property增强
#pragma mark 概念
/*
 一、
     从Xcode4.4以后 Apple 对 @property进行一个增强,以后只要利用一个 @property 就可以同时生成 setter 、 getter 方法的声明 和实现
     没有告诉 @property 要将传入的参数赋值给谁,默认 @property 会将传入的属性 赋值给 _开头的成员变量
     
     @property 有一个弊端: 他只会生成 最简单的getter\setter方法的声明和实现,并不会对传入的数据进行过滤
     如果想对传入的数据进行过滤,那么我们就必须重写 setter\getter方法
     如果不想对传入的数据进行过滤,仅仅是提供一个方法给外界操作变量,那么就可以使用
     
     如果利用 @property来生成 getter/setter方法,那么我们可以不写成员变量,系统会自动给我们生成一个 _开头的成员变量
     注意: @property 自动带我们生成的成员变量 是 一个私有的成员变量, 也就是说是.m文件中生成的,而不是在.h文件中生成的
 二、
     如果重写了setter方法,那么property就只会生成getter方法
     如果重写了getter方法,那么property就只会生成setter方法
     如果同时 重写了getter/setter方法,那么@property就不会自动 带我们生成私有的成员变量
 三、注意:
     系统 和 @synthesize 有点区别
     系统直接赋值给 _age
     而使用 @synthesize age; 系统 则会赋值给 age;
 */
#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:25];
//    NSLog(@"age = %i",[p age]);
#pragma 验证系统赋值给那个age? _age?
    /*
     注意:
     系统 和 @synthesize 有点区别
     系统直接赋值给 _age
     而使用 @synthesize age; 系统 则会赋值给 age;
     */
//    NSLog(@"age = %i, _age = %i",p->age,p->_age);
//    p->_age
    return 0;
}

######Person

>>>.h
#import <Foundation/Foundation.h>

@interface Person : NSObject
/*
{
    @public
    int _age;
    int age;
}
 */

#pragma @property增强
/*
 从Xcode4.4以后 Apple 对 @property进行一个增强,以后只要利用一个 @property 就可以同时生成 setter 、 getter 方法的声明 和实现
 没有告诉 @property 要将传入的参数赋值给谁,默认 @property 会将传入的属性 赋值给 _开头的成员变量
 
 @property 有一个弊端: 他只会生成 最简单的getter\setter方法的声明和实现,并不会对传入的数据进行过滤
 如果想对传入的数据进行过滤,那么我们就必须重写 setter\getter方法
 如果不想对传入的数据进行过滤,仅仅是提供一个方法给外界操作变量,那么就可以使用
 
 如果利用 @property来生成 getter/setter方法,那么我们可以不写成员变量,系统会自动给我们生成一个 _开头的成员变量
 注意: @property 自动带我们生成的成员变量 是 一个私有的成员变量, 也就是说是.m文件中生成的,而不是在.h文件中生成的
 */
/*
 - (void)setAge:(int)age;
 - (int)age;
 */


// 这里不知道赋值给 同名的age 还是 _age?
@property int age;
@end

>>>.m
#import "Person.h"

@implementation Person

/*
 {
    int _age;
 }
 - (void)setAge:(int)age
 {
    _age = age;
 }
 - (int)age
 {
    _age = age;
 }

 */

/*
 如果重写了setter方法,那么property就只会生成getter方法
 如果重写了getter方法,那么property就只会生成setter方法
 如果同时 重写了getter/setter方法,那么@property就不会自动 带我们生成私有的成员变量
 */
- (void)setAge:(int)age
{
    if (age < 0) {
        age = 0;
    }
    _age = age;
}
@end

转载于:https://my.oschina.net/u/3561184/blog/1377179

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值