使用Spring通过构造函数依赖注入一个bean。
1. IOutputGenerator
它的接口和实现类。
package com.mkyong.output;
public interface IOutputGenerator
{
public void generateOutput();
}
package com.mkyong.output.impl;
import com.mkyong.output.IOutputGenerator;
public class JsonOutputGenerator implements IOutputGenerator
{
public void generateOutput(){
System.out.println("This is Json Output Generator");
}
}
2.助手班
一个帮助器类,稍后使用Spring通过构造函数对IOutputGenerator进行DI。
package com.mkyong.output;
import com.mkyong.output.IOutputGenerator;
public class OutputHelper {
IOutputGenerator outputGenerator;
public void generateOutput() {
outputGenerator.generateOutput();
}
//DI via constructor
public OutputHelper(IOutputGenerator outputGenerator){
this.outputGenerator = outputGenerator;
}
}
3.弹簧配置
参见下面的Spring bean配置,Spring将通过构造函数“ public OutputHelper(IOutputGenerator outputGenerator) ”将“ JsonOutputGenerator”上方的DI插入此“ OutputHelper”类。
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-2.5.xsd">
<bean id="OutputHelper" class="com.mkyong.output.OutputHelper">
<constructor-arg>
<ref bean="JsonOutputGenerator" />
</constructor-arg>
</bean>
<bean id="JsonOutputGenerator" class="com.mkyong.output.impl.JsonOutputGenerator" />
</beans>
4.运行
加载所有内容,然后运行它。
package com.mkyong.common;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import com.mkyong.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
构造函数类型的歧义
对于支持多个参数的构造函数,将导致常见的构造函数注入类型歧义问题,请阅读此解决方案 。
对于支持多个参数的构造函数,将导致常见的构造函数注入类型歧义问题,请阅读此解决方案 。
下载源代码
下载它– Spring-DI-constructor-example.zip (6KB)