Spring DI через конструктор
Использует Spring для зависимости, вводит bean-компонент через конструктор.
1. IOutputGenerator
Интерфейс и класс реализации этого.
package com.example.output; public interface IOutputGenerator { public void generateOutput(); }
package com.example.output.impl; import com.example.output.IOutputGenerator; public class JsonOutputGenerator implements IOutputGenerator { public void generateOutput(){ System.out.println("This is Json Output Generator"); } }
2. Хелпер класс
Вспомогательный класс, позже используйте Spring для DI IOutputGenerator через конструктор.
package com.example.output; import com.example.output.IOutputGenerator; public class OutputHelper { IOutputGenerator outputGenerator; public void generateOutput() { outputGenerator.generateOutput(); } //DI via constructor public OutputHelper(IOutputGenerator outputGenerator){ this.outputGenerator = outputGenerator; } }
3. Конфигурация пружины
См. Ниже конфигурацию bean-компонента Spring, Spring будет выполнять DI выше «JsonOutputGenerator» в этот класс «OutputHelper» через конструктор «public OutputHelper(IOutputGenerator outputGenerator)».
4. Запустить его
Загрузите все и запустите.
package com.example.common; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; import com.example.output.OutputHelper; public class App { public static void main(String[] args) { ApplicationContext context = new ClassPathXmlApplicationContext( "SpringBeans.xml"); OutputHelper output = (OutputHelper)context.getBean("OutputHelper"); output.generateOutput(); } }
Выход
This is Json Output Generator
Constructor type ambiguities
Для конструктора, поддерживающего несколько параметров, это приведет к общей проблеме неоднозначности типа внедрения конструктора, прочтите этотsolution.
Скачать исходный код
Скачать -Spring-DI-constructor-example.zip (6KB)