版权声明:欢迎指出错误,作者极懒,常常懒得修改 https://blog.csdn.net/KevinAshen/article/details/86675570
参考文章
用前缀避免命名空间冲突
- 使用@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环境下,变量的内存管理语义可以通过修饰符指明,而原来则需要手工执行“保留”及“释放”操作