源码工作室

目标:通俗的语言说出通俗的技术
随笔 - 99, 文章 - 0, 评论 - 1183, 阅读 - 79万
  博客园  :: 首页  :: 新随笔  :: 联系 :: 管理

谁拥有接口?

Posted on   源码工作室  阅读(1981)  评论(0编辑  收藏  举报
    在我的文章家庭财务总管--软件设计中,有这么两个类:CModelBaseCFFMModelCFFMModelCModelBase的派生类。当时设计的时候,觉得挺好,这两者就应该有点联系,从名字上看,一看就知道CModelBaseCFFMModel父类,其名表其意。然而这样真的好吗?

有这么一段话:“接口是属于它的客户,而不是它的派生。”当我读到这段话时,我挺有感触。客户和接口之间的逻辑绑定关系要强于接口和它的派生之间的逻辑绑定关系。我们平时经常说的“顾客就是上帝”,就是这个道理。其实在设计软件的时候,我们也就必须好好考虑,如果你的接口容易引起误解,或者接口过于复杂,那使用的人(也就是所谓的客户)就不太愿意使用,虽然在这里,客户可能不太明确,因为调用者很可能是你的同事,但是只要调用了你的接口,那他就是客户,你就得对他负责。

在这里有一个例子:



 

在这里,如果接口类取名为CLightInterface,那么客户一看就认为这个类只能处理CLight的对象,然而实际上CLightInterface能处理所有具有开关操作的对象。

所以,我在编写家庭财务总管代码时,就毫不犹豫的把CModelBase改为CViewOperate,可能在我的程序中,没有多大的作用,但是习惯就是需要慢慢养成的。

Keep in mind,接口是属于客户的。

编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架
点击右上角即可分享
微信分享提示