OOD之依赖倒置原则

[u][i]这个系列是早前发布在部门wiki上的,引导组里的兄弟入门OOD,希望同样对刚刚走到OOD门前的同学有用。 [/i][/u]

在我们目前的开发模式下--使用Spring面向接口编程,这个原则给我们的更多是思维方式上的指导。所以在这里只是简单介绍一下这个原则,不举我们系统中的例子说明了。

先解释一下"依赖"这个词的含义,在软件世界里,引用、继承、实现(realization)、方法参数和本地变量引用都是一个对象对另一个对象的依赖,DIP原则告诉我们:

1、高层模块不应该依赖于底层模块,二者都应该依赖于抽象
2、抽象不应该依赖于细节,细节应该依赖于抽象

这个原则中所说的倒置"不仅仅是依赖关系的倒置,它也是接口所有权的倒置",就是说,客户或者高层模块应该拥有接口,而服务或者底层模块应该实现该接口。按照这种思路,GatewayPayOrderDAO这个接口不应该属于technicalservice层,而应该属于domain层,因为它是domain层需要的一个服务,technicalservice层只是提供了这个服务的实现而已。按照David老师最初的设想,这样的接口应该放在独立的包中,客户和实现都依赖于它。

依赖于具体并不总是危险的,如果这个具体的类/模块是稳定的,就可以依赖于它。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值