赞
踩
【编者按】随着近来软件规模的日益庞大,API编程接口的设计变的越来越重要。良好的接口设计可以降低系统各部分之间的相互依赖,提高组成单元的内聚性,降低组成单元间的耦合度,从而提高系统的维护性和稳定性。
Joshua Bloch是美国著名程序式设计师。他为Java平台设计并实现了许多的功能,是Google的首席Java架构师(Chief Java Architect)。他也是《Effective Java Programming Language Guide》一书的作者,就是人们常说的Effective Java。本文翻译自Joshua Bloch所发表的一个PPT: How to Design a Good API and Why it Matters。
随着大数据、公共平台等互联网技术的日益成熟,API接口的重要性日益凸显,从公司的角度来看,API可以算作是公司一笔巨大的资产,公共API可以捕获用户、为公司做出许多贡献。对于个人来说,只要你编程,你就是一个API设计者,因为好的代码即是模块——每个模块便是一个API,而好的模块会被多次使用。此外,编写API还有利于开发者提高代码质量,提高自身的编码水平。
优秀API所具备的特征
了解了一款优秀API所具备的特征后,一起再来看看如何设计优秀的API,有哪些流程和规则可循,开发者在设计时需要注意哪些事项。
API设计流程中的注意事项
征集需求
在开始之前,你可能会收到一些解决方案,它们不一定会比现有的方案好,而你的任务是以用例的形式提取真实需求,并制定真正合适的解决方案,这样构建出来的东西就会更加有价值。
从简短的说明开始
这时,编写简短的说明最为合适,编写时需要考虑的因素有:
尽早编写API
编写SPI尤为重要
维护切实可行的期望
API设计原则
每个API接口应该只专注一件事,并做好:如果它很难命名,那么这或许是个不好的征兆,好的名称可以驱动开发、并且只需拆分与合并模块即可
重视文档
开发API时要意识到文档的重要性。组件重用不是纸上谈兵的东西,既需要好的设计,也需要优秀的文档,这二者缺一不可,即使我们看到了良好的设计而未见文档,那么组件重用也是不妥的。
——摘自 D. L. Parnas 在1994年第16届国际软件开发大会上的演讲内容
文档应包含每个类、接口、方法、构造函数、参数和异常,此外,还要小心对待文档的状态空间。
API设计决策对性能的影响
API与平台和平共处
API中类的设计
最小化可变性
子类只存在有意义的地方
用于继承的设计和文档或者直接禁止继承(Design and Document for Inheritance or Else Prohibit it)
API中的方法设计
减少模板代码的使用:
用户API只需根据需求来设计即可,不必让客户感到惊讶,小心弄巧成拙:
使用合适的参数和返回类型
java.util.Collections – first parameter always collection to be modified or queried避免使用长参数列表
java.util.concurrent – time always specified as long delay, TimeUnit unit
最好避免这种情况出现:
返回值勿需进行异常处理
比如,返回零长度字符串或者空集合
抛出异常来说明异常状况;不要强迫客户端使用异常来控制流。
支持Unchecked Exceptions
重构API设计
在Vector中进行Sublist操作
重构Sublist操作
线程局部变量
API设计是一件非常高端大气上档次的工艺,对程序员、终端用户和公司都会有所提升。不要盲目地去遵守文中所提及的规则、说明等,但也不要去侵犯他们,API设计不是件简单的工艺,也不是一种可以孤立行动的活。当然完美永远无法实现,但我们要努力去追求完美。
附上Joshua Bloch的PPT:
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。