[ObjectC]Objective-C内存管理之---属性修饰词

iOS经典面试题总结--内存管理 :
分别写一个setter方法用于完成@property (nonatomic,retain)NSString *name和@property (nonatomic,copy) NSString *name

-(void)setName:(NSString *)name
{
    [name retain];
    [_name release];
    _name = name;
}
-(void)setName:(NSString *)name
{     
    [_name release];
    _name = [name copy];
}
retain属性的setter方法是保留新值并释放旧值,然后更新实例变量,令其指向新值。顺序很重要。假如还未保留新值就先把旧值释放了,而且两个值又指向同一个对象,先执行的release操作就可能导致系统将此对象永久回收。

当把属性的语义特性分别声明为assign,retain,copy时, 自动生成setter, getter方法内部实现
假定有一个车类Car.h中定义三个属性
@property (nonatomic, retain) NSString * brand; //品牌
@property (nonatomic, copy) NSString * colour;  //颜色
@property (nonatomic, assign) CGFloat  price;   //价格
以下是把属性的语义特性分别声明为assign,retain,copy时, 自动生成setter, getter方法内部实现:

    //当把属性的语义特性声明为retain时,自动生成setter方法内部实现
    - (void)setBrand:(NSString *)brand
    {
        if (_brand != brand) {//如果旧值不等于新值
            [_brand release];//旧值先release
            _brand = [brand retain];//新值retain赋值给旧值
        }
    }    

    //当把属性的语义特性声明为retain时,自动生成getter方法内部实现
    - (NSString *)brand
    {
        return [[_brand retain] autorelease];
    }  

    //当把属性的语义特性声明为copy时,自动生成setter方法内部实现
    - (void)setColor:(NSString *)color
    {
        if (_color != color) {
            [_color release];
            _color = [color copy];
        }
    }    

    //当把属性的语义特性声明为copy时,自动生成getter方法内部实现
    - (NSString *)color
    {
        return [[_color retain] autorelease];
    }    

    //当把属性的语义特性声明为assign时,自动生成setter方法内部实现
    - (void)setPrice:(CGFloat)price
    {
        _price = price;
    }    

    //当把属性的语义特性声明为assign时,自动生成getter方法内部实现
    - (CGFloat)price
    {
        return _price;
    }

展开阅读全文

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 技术黑板 设计师: CSDN官方博客
应支付0元
点击重新获取
扫码支付

支付成功即可阅读