update :05. 使用依赖注入取代硬连接资源(hardwiring resources)

This commit is contained in:
sjsdfg 2019-04-05 16:24:44 +08:00
parent 75cfb8eadd
commit e99a810a25

View File

@ -53,7 +53,7 @@ public class SpellChecker {
```
  依赖注入模式非常简单,许多程序员使用它多年而不知道它有一个名字。 虽然我们的拼写检查器的例子只有一个资源(字典),但是依赖项注入可以使用任意数量的资源和任意依赖图。 它保持了不变性(条目 17因此多个客户端可以共享依赖对象假设客户需要相同的底层资源。 依赖注入同样适用于构造方法,静态工厂(条目 1和 builder 模式(条目 2
  该模式的一个有用的变体是将资源工厂传递给构造方法。 工厂是可以重复调用以创建类型实例的对象。 这种工厂体现了工厂方法模式Factory Method pattern [Gamma95]。 Java 8 中引入的 `Supplier<T>` 接口非常适合代表工厂。 在输入上采用 `Supplier<T>` 的方法通常应该使用有界的通配符类型 ( bounded wildcard type)(条目 31约束工厂的类型参数以允许客户端传入工厂创建指定类型的任何子类型。 例如,下面是一个使用客户端提供的工厂生成 tile 的方法:
  该模式的一个有用的变体是将资源工厂传递给构造方法。 工厂是可以重复调用以创建类型实例的对象。 这种工厂体现了工厂方法模式Factory Method pattern[Gamma95]。 Java 8 中引入的 `Supplier<T>` 接口非常适合代表工厂。 在输入上采用 `Supplier<T>` 的方法通常应该使用有界的通配符类型bounded wildcard type(条目 31约束工厂的类型参数以允许客户端传入工厂创建指定类型的任何子类型。 例如,下面是一个使用客户端提供的工厂生成 tile 的方法:
```java
Mosaic create(Supplier<? extends Tile> tileFactory) { ... }
@ -61,4 +61,4 @@ Mosaic create(Supplier<? extends Tile> tileFactory) { ... }
  尽管依赖注入极大地提高了灵活性和可测试性,但它可能使大型项目变得混乱,这些项目通常包含数千个依赖项。使用依赖注入框架(如 Dagger [Dagger]、Guice [Guice] 或 Spring [Spring])可以消除这些混乱。这些框架的使用超出了本书的范围,但是请注意,为手动依赖注入而设计的 API 非常适合这些框架的使用。
  总之,不要使用单例或静态的实用类来实现一个类,该类依赖于一个或多个底层资源,这些资源的行为会影响类的行为,并且不让类直接创建这些资源。相反,将资源或工厂传递给构造方法 (或静态工厂或 builder 模式)。这种称为依赖注入的实践将极大地增强类的灵活性、可重用性和可测试性。
  总之,不要使用单例或静态的实用类来实现一个类,该类依赖于一个或多个底层资源,这些资源的行为会影响类的行为,并且不让类直接创建这些资源。相反,将资源或工厂传递给构造方法(或静态工厂或 builder 模式)。这种称为依赖注入的实践将极大地增强类的灵活性、可重用性和可测试性。