IOC
@ComponentScan
@Scope:
singleton:ioc生成时自动创建好,只有一个
prototype:getBean时才会创建,每次都是新的
@Lazy
懒加载,容器启动时不创建,第一次getBean时创建(与scope不冲突)
@Conditional
通过实现condition接口,判断是否将对应对象加载到ioc中
@Import
快速给容器导入组件
写法:1.@Controller @Service @Repository 多用于自己写的类;
2.@Bean 多用于外部导入的类;
3.@Import 同2,用法:@Import(A.class),导入一个A类的对象;
实现ImportSelector接口;
实现ImportBeanDefinitionRegistry接口;
4.FactoryBean接口;
bean生命周期:
初始化:对象创建完成并赋值,调用初始化方法
销毁:单实例:容器关闭时调用
多实例:容器不调用,可以手动调用
流程:instantiate
-> populateBean
-> { ->invokeAwareMethods
->applyBeanPostProcessorsBeforeInitialization
->invokeInitMethods {afterPropertiesSet -> initMethod}
-> applyBeanPostProcessorsAfterInitialization
}
@Value注解
对int String等类型参数进行传值
写法:1、基本数值 2、#{SpEl} 3、${配置文件}
@Autowired(spring规范注解 )
自动装配,首先按照类型装配,同类型按照名称id装配(@Qualifier指定装配特定对象)
required属性为false时,如果没有可装配的对象,原对象也可以初始化成功;默认为true,没有可装配对象时会抛异常。
( @Primary,注解在被装配对象上,ioc中存在同类型的多个对象时,这个注解的对象被装配的优先级最高。)
可以注解在方法上(set方法或者其他方法)、构造器上、构造器入参上,只有一个有参构造器时,可以省略该注解:
此处Autowired注解在set方法上,且可以省略该注解;
此处Autowired注解在方法上,且可以省略该注解;
此处Autowired注解在构造器入参上,同样可以省略;
此处Autowired注解在构造器上,同样可以省略;
@Resource(java规范注解,不是spring规范注解),与Autowired基本类似;
@inject(java规范注解,不是spring规范注解),与Autowired基本类似。
如何使用ioc中的ApplicationContext等组件:
1、实现ApplicationContextAware接口,通过setApplicationContext方法获取到ApplicationContext;
2、构造器中增加ApplicationContext类型传参
@Profile:指定组件在特定环境下才能被加载到IOC中,不指定的话,任何环境都会对此组件进行加载。
此注解可以添加在方法上或者类上,类上的注解未被匹配到时,类中方法均不会执行。用法如下:
1、@Profile("test)
public A getA() {...}
2、@Profile("test)
class A {...}
如何指定环境?
1、命令行参数-Dspring.profile.active=test
2、代码中设置需要激活的环境:
相当于在ioc的无参构造器this()和register()之间增加一个设置环境的步骤。
AOP动态代理
流程如下:
注意点:
1、要用spring管理的实例,不能自己new出来,否则aop无法生效;
2、@AfterReturning、@Around等注解标注的方法里, 可以传JoinPoint、Exception等多个参数,但是JoinPoint类型的参数必须放在首位,如下:
事务性注解
@EnableTransactionManagement
其他内容
BeanDefinitionRegistryPostProcessor:
BeanDefinitionRegistry类是bean的信息保存中心,以后beanfactory就是根据BeanDefinitionRegistry中的信息注册bean的
beanFactoryPostProcessor:
ApplicationListener:
监听容器中发布的事件(事件驱动模型开发):
写一个监听器ApplicationListener实现类 == @EventListener