在我的文章家庭财务总管--软件设计中,有这么两个类:CModelBase和CFFMModel,CFFMModel是CModelBase的派生类。当时设计的时候,觉得挺好,这两者就应该有点联系,从名字上看,一看就知道CModelBase是CFFMModel父类,其名表其意。然而这样真的好吗?
有这么一段话:“接口是属于它的客户,而不是它的派生。”当我读到这段话时,我挺有感触。客户和接口之间的逻辑绑定关系要强于接口和它的派生之间的逻辑绑定关系。我们平时经常说的“顾客就是上帝”,就是这个道理。其实在设计软件的时候,我们也就必须好好考虑,如果你的接口容易引起误解,或者接口过于复杂,那使用的人(也就是所谓的客户)就不太愿意使用,虽然在这里,客户可能不太明确,因为调用者很可能是你的同事,但是只要调用了你的接口,那他就是客户,你就得对他负责。
在这里,如果接口类取名为CLightInterface,那么客户一看就认为这个类只能处理CLight的对象,然而实际上CLightInterface能处理所有具有开关操作的对象。
所以,我在编写家庭财务总管代码时,就毫不犹豫的把CModelBase改为CViewOperate,可能在我的程序中,没有多大的作用,但是习惯就是需要慢慢养成的。
Keep in mind,接口是属于客户的。