建议有“英文阅读能力”的看一下,下面这篇文章的以下回答:java - Dependency Injection - Proper use of interfaces? - Stack Overflow
看了很多文章,并没有找到为什么依赖注入的时候选择接口而不是实现类比较好的回答。
基本都在说什么“面向接口编程”这种片面话或者就是太难了(什么事务,动态代理,向上转型...)我这种小白完全摸不着头脑,搞得我很是恼火,就去外网找了一些简单的解释。
以下是我翻译了其中某一个我能够理解的回答,配上代码。
正确的写法应该是在MyStorageClient里传入接口,如下图
如果在MyStorageClient处选择了与UserStorageDB实现类强关联,如下图
简而言之就是:除非 UserStorageTextFile 继承 UserStorageDB之外,不可能将MyStorageClient与 UserStorageTextFile类连接起来了。所以缺点就是:如果您只想编写一个简单的文本文件,但是由于【上图,MyStorageClient处选择了与UserStorageDB实现类强关联】,所以必须依赖于Oracle 驱动程序。也就是说UserStorageTextFile与UserStorageDB这个类莫名其妙地强关联了,就很耦合。