Effiective objecttive -c2.0 这本书说 在初始化方法和dealloc方法总是应该通过实例变量来读写数据,看了半天没看懂原因到底是为什么?有看这本书的吗?
书中不是讲的很清楚吗:
_name = @"Jack" 不经过setter的消息发送,直接为变量赋值,速度快。
_name = @"Jack"
对于以下的 name 属性:
name
@property (nonatomic, copy) NSString *name;
直接赋值是: _name = @"Jack"; ,通过 self.name = @"Jack" 其实等同于 _name = @"Jack".copy;
_name = @"Jack";
self.name = @"Jack"
_name = @"Jack".copy
self.name = @"Jack" 会触发KVO,_name = @"Jack" 会触发KVO,
NSString *str = _name,赋值用 self.name = @"Jack"所以有一种合理折中方案就是,读取数据的时候用 NSString *str = _name,赋值用
NSString *str = _name
self.name = @"Jack"可能不等同于 _name = @"Jack".copy另外需要注意的是子类可能复写setter方法,用
书中不是讲的很清楚吗:
_name = @"Jack"
不经过setter的消息发送,直接为变量赋值,速度快。对于以下的
name
属性:直接赋值是:
_name = @"Jack";
,通过self.name = @"Jack"
其实等同于_name = @"Jack".copy
;
不会self.name = @"Jack"
会触发KVO,_name = @"Jack"
会触发KVO,
可以在 setter 方法中进行断点调试,每次赋值你都知道。self.name = @"Jack"
NSString *str = _name
,赋值用self.name = @"Jack"
所以有一种合理折中方案就是,读取数据的时候用NSString *str = _name
,赋值用self.name = @"Jack"
可能不等同于_name = @"Jack".copy
另外需要注意的是子类可能复写setter方法,用_name = @"Jack".copy
。