阅读 84

编写高质量iOS与OS X代码的52个有效方法 - 学习笔记 3、4



第三章   接口与 API 设计

15、用前缀避免命名空间冲突

Objective-C 没有其他语言那种内置的命名空间(namespace)机制。所以,我们在起名时要设法避免潜在的命名冲突。
Apple 宣称其保留使用所有“两字母前缀”的权利
  • 选择与你的公司、应用程序或二者皆有关联之名之称作为类名的前缀,并在所有代码中均使用这一前缀。
  • 若自己所开发的程序中用到了第三方库,则应为其中的名称加上前缀。


16、提供“全能初始化方法”

每个子类的全能初始化方法都应该调用其超类对应方法,并逐层向上。
  • 在类中提供一个全能初始化方法,并与文档里指明。其他初始化方法均应调用此方法。
  • 若全能初始化方法与超类不同,则需覆写超类中的对应方法。
  • 如果超类的初始化方法不适用于子类,那么应该覆写这个超类方法,并在其中抛出异常。


17、实现 descripition 方法

  • 实现 description 方法返回一个有意义的字符串,用以描述该实例。
  • 若想在调试时打印出更详尽的对象描述信息,则应实现 debugDescription 方法。


18、尽量使用不可变对象

设计类的时候,应充分运用属性来封装数据。而在使用属性时,则可将其声明为“只读”(read-only),建议大家尽量减少对象中的可变内容
  • 尽量创建不可变的对象
  • 若某属性仅可于对象内部修改,则在分类中将其由 readonly 属性扩展为 readwrite 属性。
  • 不要把可变的 collection 作为属性公开,应提供相关方法,以此修改对象中的可变  collection。


19、使用清晰而协调的命名方式

Objective-C的命名方式虽然长一点,但却非常清晰。
  • 起名时应遵从标准的OC命名规范,这样创建出来的接口更容易为开发者所理解。
  • 方法要言简意赅,从左至右读起来要像个日常用语中的句子。
  • 方法名里不要使用缩略后的类型名称。
  • 方法起名第一要务是确保风格与项目或所要集成的框架相符。


20、为私有方法名加前缀

为私有方法加前缀目的是为了与公共方法区分开。还有个原因就是便于修改方法名或方法签名。
  • 给私有方法的名称加上前缀便于与公共方法区分开。
  • 不要单用一个下划线做私有方法的前缀,因为这种做法是预留给苹果公司用的。


21、理解 Objective-C 错误类型

OC语言针对异常的做法:只在极其罕见的情况下抛出异常,异常抛出之后,无须考虑恢复问题,而且应用程序此时也应该退出。这就是说,不用再编写复杂的“异常安全”代码了。
  • 只有发生了可使整个应用程序崩溃的严重错误时,才应使用异常。
  • 在错误不那么严重的情况下,可以指派“委托方法”(delegate method)来处理错误,也可以把错误信息放在 NSError 对象里,经由“输出参数”返回给调用者。


22、理解 NSCopying 协议

如果想令自己的类支持拷贝操作,那就要实现 NSCopying 协议,该协议只有一个方法:

- (id)copyWithZone:(NSZone *)zone;

  • 若想令自己所写的对象具有拷贝功能,则需实现 NSCopying 协议。
  • 如果自定义的对象分为可变版本与不可变版本,那么就要同时实现 NSCopying 与 NSMutableCopying 协议。
  • 复制对象时需决定采用浅拷贝还是深拷贝,一般情况下应该尽量执行浅拷贝。
  • 如果你所写的对象需要深拷贝,那么可考虑新增一个专门执行深拷贝的方法。



第四章 协议与分类

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

  • 委托模式为对象提供了一套接口,使其可由此将相关事件告知其他对象。
  • 将委托对象应该支持的接口定义成协议,在协议中把可能需要处理的事件定义成方法。
  • 当某个对象需要从另一个对象中获取数据时,可以使用委托模式。这种情况下,该模式亦称“数据源协议”。
  • 若有必要,可实现含有位段的结构体,将委托对象是否能响应相关协议方法这一信息缓存至其中。


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

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


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

  • 向第三方类中添加分类时,总应给其名称加上你专用的前缀。
  • 向第三方类中添加分类时,总应给其中的方法名加上你专用的前缀。


26、勿在分类中声明属性

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


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

“class-continuation 分类” 和普通的分类不同,它必须定义在其所接续的那个类的实现文件里。其重要之外在于,这是唯一能声明实例变量的分类,而且此分类没有特定的实现文件,其中的方法都应该定义在类的主实现文件里。与其他分类不同,该分类没有名字。
  • 通过 “class-continuation 分类” 向类中新增实例变量。
  • 如果某属性在主接口中声明为 “只读”,而类的内部又要用设置方法修改此属性,那么就在 “class-continuation 分类” 中将其扩展为 “可读写”。
  • 把私有方法的原型声明在 “class-continuation 分类” 里面。
  • 若想使类所遵循的协议不为人所知,则可于 “class-continuation 分类” 中声明。


28、通过协议提供匿名对象

  • 协议可在某种程度上提供匿名类型。具体的对象类型可以淡化称遵从某个协议的 id 类型,协议里规定了对象所实现的方法。
  • 使用匿名对象来隐藏类型名称(或类名)。
  • 如果具体类型不重要,重要的是对象能够响应协议方法,那么可使用匿名对象来表示。