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)