2015-07-24 11:32:22 +03:00
|
|
|
package com.iluwatar.dependency.injection;
|
2015-05-25 18:41:54 +03:00
|
|
|
|
2015-05-25 18:38:42 +03:00
|
|
|
import com.google.inject.Guice;
|
|
|
|
import com.google.inject.Injector;
|
|
|
|
|
2015-05-25 19:13:50 +03:00
|
|
|
/**
|
|
|
|
*
|
|
|
|
* Dependency Injection pattern deals with how objects handle their dependencies. The pattern
|
|
|
|
* implements so called inversion of control principle. Inversion of control has two specific rules:
|
|
|
|
* - High-level modules should not depend on low-level modules. Both should depend on abstractions.
|
|
|
|
* - Abstractions should not depend on details. Details should depend on abstractions.
|
2015-08-18 22:17:16 +03:00
|
|
|
* <p>
|
|
|
|
* In this example we show you three different wizards. The first one ({@link SimpleWizard}) is a naive
|
2015-05-25 19:13:50 +03:00
|
|
|
* implementation violating the inversion of control principle. It depends directly on a concrete
|
|
|
|
* implementation which cannot be changed.
|
2015-08-18 22:17:16 +03:00
|
|
|
* <p>
|
|
|
|
* The second wizard ({@link AdvancedWizard}) is more flexible. It does not depend on any concrete implementation
|
|
|
|
* but abstraction. It utilizes Dependency Injection pattern allowing its {@link Tobacco} dependency to be
|
2015-05-25 19:13:50 +03:00
|
|
|
* injected through its constructor. This way, handling the dependency is no longer the wizard's
|
|
|
|
* responsibility. It is resolved outside the wizard class.
|
2015-08-18 22:17:16 +03:00
|
|
|
* <p>
|
2015-05-25 19:13:50 +03:00
|
|
|
* The third example takes the pattern a step further. It uses Guice framework for Dependency Injection.
|
2015-08-18 22:17:16 +03:00
|
|
|
* {@link TobaccoModule} binds a concrete implementation to abstraction. Injector is then used to create
|
|
|
|
* {@link GuiceWizard} object with correct dependencies.
|
2015-05-25 19:13:50 +03:00
|
|
|
*
|
|
|
|
*/
|
2015-05-25 18:41:54 +03:00
|
|
|
public class App {
|
|
|
|
|
2015-08-18 22:17:16 +03:00
|
|
|
/**
|
|
|
|
* Program entry point
|
|
|
|
* @param args command line args
|
|
|
|
*/
|
2015-05-25 18:41:54 +03:00
|
|
|
public static void main( String[] args ) {
|
2015-05-22 23:37:42 +03:00
|
|
|
SimpleWizard simpleWizard = new SimpleWizard();
|
|
|
|
simpleWizard.smoke();
|
|
|
|
|
|
|
|
AdvancedWizard advancedWizard = new AdvancedWizard(new SecondBreakfastTobacco());
|
|
|
|
advancedWizard.smoke();
|
2015-05-25 18:38:42 +03:00
|
|
|
|
|
|
|
Injector injector = Guice.createInjector(new TobaccoModule());
|
|
|
|
GuiceWizard guiceWizard = injector.getInstance(GuiceWizard.class);
|
|
|
|
guiceWizard.smoke();
|
2015-05-25 18:41:54 +03:00
|
|
|
}
|
|
|
|
}
|