Effective Objective-C 2.0 阅读笔记 四

参考文章

  • iOS 抛出异常@throw

用前缀避免命名空间冲突

  • 使用@throw抛出异常, 抛出后程序会直接退出
    @throw [NSException exceptionWithName:@"context show" 
                                   reason:@"crush's reason" 
                                 userInfo:nil];
  • Objective-C中只有在严重错误才会使用抛出异常

理解NSCopying协议

  • 如果我们需要在直接的类中实现拷贝功能
    • 首先遵守NSCopying协议
    • 实现协议中- (id)copyWithZone:(nullable NSZone *)zone方法
    - (id)copyWithZone:(nullable NSZone *)zone {
        EOCPerson *copy = [[[self class] allocWithZone:zone] 
                            initWithFirstName:_firstName 
                                  andLastName:_lastName];
        return copy;
    }
  • 浅拷贝:浅拷贝之后的对象与原始对象均指向相同内容
  • 深拷贝:深拷贝之后的内容所指的对象是原始内容中相关对象的一份拷贝
  • 如果自定义对象要有可变版本, 需要引入NSMutableCopying协议
  • 一般使用浅拷贝

通过委托与数据源协议进行对象间通信

  • 协议可以使用字段结构体来存储是否响应(mark)

将类的实现代码分散到便于管理的数个分类之中

  • 使用分类机制把类的实现代码划分成易于管理的小块
  • 将应该视为"私有"的方法归入名叫Private的分类中, 以隐藏实现细节(mark)

总是为第三方类的分类名称加前缀

  • 类中的方法如果和分类中的方法同名, 分类中的方法会把类中的方法覆盖掉
  • 为了防止重名, 每个分类以及分类里的方法都要加前缀(mark)

勿在分类中标明属性

  • 把封装数据所用的全部属性都定义在主接口里
  • 在“class-continuation分类”之外的其他分类中, 可以定义存取方法, 但尽量不要定义属性

使用“class-continuation分类”隐藏实现细节

  • 将只供本类使用的变量写在class-continuation分类里, 防止被外界篡改
  • 协议申明在class-continuation里,使得其外界不可知
  • 总结一下:将需要被暴露的方法路在外面, 将私有变量和私有方法放在class-continuation

通过协议提供匿名对象

  • 协议可在某种程度上提供匿名类型。具体的对象类型可以淡化成遵从某协议的id类型,协议里规定了对象所应实现的方法
  • 使用匿名对象来隐藏类型名称(或类名)
  • 如果具体类型不重要,不重要饿的对象能够响应(定义在协议里的)特定方法,那么可以使用匿名对象
  • @property (nonatomic, weak) id delegate意味这受委托者可以是任意类型

内存管理

  • 引用记数机制通过可以递增递减的记数器来管理内存。对象创建好以后,其保留记数至少为一。若保留记数为正,则对象继续存活。点那个保留记数降为0时,对象就被销毁了。
  • 在对象生命期中,其余对象通过引用来保留或释放次对象。保留与释放操作分别会递增及递减保留记数
  • alloc时引用计数不一定就是1,要看内部具体实现
  • 避免引用环即循环引用,A引用B,B引用C,C引用A,导致ABC为一个封闭的引用环,永远无法释放

以ARC简化引用记数

  • 内存泄漏:没有正确释放已经不再使用的内存
  • ARC会自动执行retain,release,autorelease等操作,所以直接手工书写是违法的
  • 方法名以特定词开头,则其返回对象归调用者所有(有点神奇,OC真的是很强调命名的语言,有一种言出法随的感觉)
  • ARC管理对象生命期的办法基本上就是:在合适的地方插入“保留”及“释放”操作。在ARC环境下,变量的内存管理语义可以通过修饰符指明,而原来则需要手工执行“保留”及“释放”操作

你可能感兴趣的:(Objective-C,Effective,Objective-C,2.0,阅读笔记)