被遗忘的注释
注释通常描述了API的功能以及参数说明,以及如何接入,甚至给出简单示例,过于详细的注释会带来一定的反作用,例如因为新需求带来了内部逻辑的调整,但是由于未及时对API的注释进行更新,会给新接入的调用方带来潜在的风险。所以不仅仅需要为API提供完整清晰的注释,当内部逻辑变更时,作为开发人员通常也需要评估API层面的变更,包括注释。
接口数量持续膨胀
有很多原因带来接口数量的膨胀,可能是接口升级,但是旧接口无法直接下线,所以会提供一个功能类似的新接口;可能是新接管一个服务由于对业务不了解,面对新需求直接开发新接口;可能是接口分类划分不合理,或者数据模型混乱导致API划分混乱,出现API功能重复,最后导致一个场景多个API接口都可以满足,这样很明显是应该避免的。解决这些问题都需要建立在对业务充分理解的基础上,下文的设计原则会针对这类问题给出解决方案。
缺乏有效测试
很多开发人员往往忽略对于接口的测试,无论是内部逻辑细节的单元测试,还是接口层面的测试,都是服务健壮性的一个有效保证,如果无法对接口进行有效测试,不仅是不负责任的提现,而且还会经常被线上bug困扰。
# API设计的原则
注释应该包含哪些;
接口的使用场景,参数的说明,在接口类说明中可以给出接口文档链接地址,方便调用方查看
参数的说明;
包含参数代表的含义,参数的类型按照Javadoc link规范,参数是否为空,特殊值说明
过期说明;
如果接口已经过期,需要给出过期说明,对于Java来时就是@Deprecated注解,并给出切换接口说明,如果条件允许可以推动调用方进行接口迁移,后续对旧接口下线
唯一不变的是变化,接口也会一直演化,我们不提倡过度提前设计,但是在演化过程中要始终保持接口的可扩展性。
多参数结构与单一参数类结构
通常来说,如果一个接口的参数小于三个,那么建议使用多参数接口,这样做到直观简洁 如果一个接口的参数较多而且后续可能经常出现变动,为了便于扩展和兼容,会将参数封装到一个类结构中,记得同样对每个字段给出完整的注释说明。
类复用噩梦
在单一参数类结构下,我经常看到多个存在明显功能差异的接口频繁复用一个结构体,甚至接口参数和返回值都复用一个DTO,为了保证兼容,又不得不在同一个DTO内不断加字段,久而久之维护成本持续增高,这是一种不合理的类设计,如果遵守专注原则,这个问题很多时候可以避免
逻辑兼容
是否要新增接口
单元测试
接口和场景测试