1. xml声明方式:
<bean id="" name="" class="">
<property name="" value="" />
<property name="" ref="" />
<constructor-arg name="" value="" />
</bean>
- spring会将装配好的bean存储在map(beanName->bean对象)中。
- xml中的id对应map中的beanName,必须是唯一的
- xml中的name对应map中的bean对象的alias(别名),可以有多个,通过逗号隔开,也是唯一的。
- 可以通过beanName或者alias获取bean。
- 此处还可以通过bean类型获取bean,如果该类型的bean存在多个则会报错。
ApplicationContext context=new ClassPathXmlApplicationContext("applicationContext.xml");
Music music=(Music) context.getBean(Music.class);
- 可以不声明id和name,如果这样默认id是【全类名#0】,name(alias)默认是【全类名】,假设再声明一个同样的bean则默认ID是全类名#1,没有alias。
2. java隐式声明(注解注入)
开启注解:
<context:component-scan base-package=”com.lbl”>
或者
@ComponentScan
Class App{
AnnotationConfigWebApplicationContext context = new AnnotationConfigWebApplicationContext();
context.register(App.class);
context.refresh();
}
- 通过@Component/@Controller/@Service/@Repository等标签声明为组件
- 如果不指定id,则默认为【短类名】(首字母小写),也可以@Component(“myId”)这样指定。
- 注入可以通过@Autowired,默认根据类型注入,如果没有该类型的bean会报错,设置required=false则不会报错。
- 通过@Autowired注入时,如果有多个该类型的bean也会报错,可以添加@Qualifier(“”)指定注入bean名称
- 可以直接使用@Resource(name=”“),通过beanName匹配注入。
- 在获取spring data redis时还遇过这样注入,beanName对应的bean和type类型不一致且无继承关系,具体分析参照:https://www.cnblogs.com/tangyuanyuan/p/8067923.html
@Resource(name="redisTemplate")
private SetOperations<String, String> setOpts;
- 通过@Scope可以定义bean的范围:singleton,prototype,session,request,globalSession
3. java显示声明
由于有些类是无法在其中加注解,所以必须显示的在configuration类中通过@Bean注解装配它。