SpringBean的生命周期
在bean的配置文件中
<bean class="com.dongmu.pojo.Hello" id="hello" name="hello2,hello3" scope="prototype">
<constructor-arg type="java.lang.String" value="kksdmk"/>
<constructor-arg type="java.lang.String" value="00"/>
</bean>
scope可以指定创建的对象是否是单例的,如果不是单例的这个时候容器中会创建一个对象,我取一次它就会再创建一个,
prototype:原型模式
singleton:单例模式
三种装配的方式
1:xml中显示的配置
2:java中配置
3:引用类型的自动装配
autowire:这个标签可以再bean的内部使用
byName:按照名称自动装配,
byType:按照类型自动装配,这个时候要求类型必须全局唯一
注解:可以直接使用注解,要加入注解驱动<context:annotation-driven/>,别导错约束了,是mvc的约束
<context:annotation-config>和<context:component-scan>的区别
<context:annotation-config> 是用于激活那些已经在spring容器里注册过的bean(无论是通过xml的方式还是通过package sanning的方式)上面的注解。
<context:component-scan>除了具有<context:annotation-config>的功能之外,
<context:component-scan>还可以在指定的package下扫描以及注册javabean ,这个时候通过注解@Conponent指定名称(id),然后直接getbean就行了,不用再bean的配置文件里面注册。
另外,Spring 还提供了 3 个创建对象的注解:
➢ @Repository 用于对 DAO 实现类进行注解
➢ @Service 用于对 Service 实现类进行注解
➢ @Controller 用于对 Controller 实现类进行注解
这三个注解与@Component 都可以创建对象,但这三个注解还有其他的含义,@Service
创建业务层对象,业务层对象可以加入事务功能,@Controller 注解创建的对象可以作为处
理器接收用户的请求。
@Repository,@Service,@Controller 是对@Component 注解的细化,标注不同层的对
象。即持久层对象,业务层对象,控制层对象。
@Component 不指定 value 属性,bean 的 id 是类名的首字母小写。
这几个注解还可以联合@Scope使用指定是单例的还是原型模式
几个注解的使用:
@aruowired(required = "boolean")按照类型注入
required指定没有的时候是报错还是为null
还可以和@Qualifier联合使用指定匹配的id
Spring提供了对 jdk中@Resource注解的支持。@Resource 注解既可以按名称匹配Bean,
也可以按类型匹配 Bean。默认是按名称注入。@Resource 注解若不带任何参数,采用默认按名称的
方式注入,按名称不能注入 bean, 则会按照类型进行 Bean 的匹配注入。@Resource 注解指定其
name 属性,则 name 的值即为按照名称进行匹配的 Bean 的 id。但是这个时候就不会再按类型匹配
了,找不到就会报错。
由于使用注解,底层用到是反射,所以连set方法也不用写了。
下面说一下上面说的第二种方式java中配置
1:实体类
package com.dongmu.pojo;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;
//@Component
public class User {
@Value("DONGMU")
String name;
@Override
public String toString() {
return "User{" +
"name='" + name + '\'' +
'}';
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public User() {
}
public User(String name) {
this.name = name;
}
}
2:Java类用作配置文件
package com.dongmu.config;
import com.dongmu.pojo.User;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
@Configuration
@ComponentScan("com.dongmu.pojo")
public class DongmuConfig {
@Bean
User getUser(){
return new User();
}
}
3:使用方式
import com.dongmu.config.DongmuConfig;
import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;
public class Test {
public static void main(String[] args) {
ApplicationContext context = new AnnotationConfigApplicationContext(DongmuConfig.class);
System.out.println(context.getBean("getUser"));
}
}
当然我们还可以引入两个配置类,使用@Import注解导入其他的配置类
其实SpringBoot底层也是使用这种配置方式实现的,所以我们以后用SpringBoot不需要配置的文件实际上是人家底层已经配置好了。