当一个类声明了
@Component、@Rpository、@Service、@Controller
这几个注解时,当我们启动服务器的时候,Spring通过代理反射来生成这个类的对象,把这个对象放在了IOC容器中。
@Service
Class CarServiceImpl
1.服务器启动
通过反射生成一个对象 carService
2.这个容器呐,其实就是一个map对象,通过map.put(“key”,value),把这个对象放在map中。
map.put(“carService”,carService)
3.在CarController里面
@AutoWried
CarService carService;
就相当于map.get(“carService”),在controller就能够操作carService对象了。
来看看代码
@Configuration
@ComponentScan({"com.cjx.controller","com.cjx.service","com.cjx.dao"})
public class AnnoConfig {
@Bean
public TestDao testDao(){
TestDao testDao=new TestDao();
testDao.setFlag(2);
return testDao;
}
}
@Configuration声明这个类是一个配置类,相当于Spring的配置文件bean.xml
@ComponentScant 自动扫描包里面的注解
@Bean注解用于方法上,说明这个类返回一个对象
public class TestDao {
public void setFlag(int a){
System.out.println(a);
}
}
public class AnnoTest {
@Test
public void test01(){
AnnotationConfigApplicationContext app= new AnnotationConfigApplicationContext(AnnoConfig.class);
}
}
AnnotationConfigApplicationContext
把刚才的配置类作为参数,传给这个context对象。
来看看AnnotationConfigApplicationContext是如何实现的
首先我们把配置类作为参数,调用的是下面这个构造函数
public AnnotationConfigApplicationContext(Class<?>... annotatedClasses) {
this();
register(annotatedClasses);
refresh();
}