spring 中bean 的扫描过程总结
作者:互联网
bean 的扫描过程
- 首先是通过ResourcePatternResolver获取指定路径下的所有.class文件,利用AMS技术来解析所有得到的class文件对象,得到class元数据信息;
- 判断扫描的class文件对象,是否和某个excludefilter条件注解匹配,匹配成功以后会根据当前类生成一个ScannedGenericBeanDefinition;
- 判断这个类是否是独立的、接口、抽象的,类上面是否有Lookup注解,符合上面的条件,就将这个类作为BeanDefinition返回;
- 解析获取到的所有的BeanDefinition,获取到对应的@Scope注解的数据,再将这个值放入到对应的BeanDefinition类中;
- 获取到对应BeanDefinition的名字(首先判断这个BeanDefinition的@Component是否指定了一个名字,有则直接返回,如果@Component注解没有指定名字,那么直接生成一个默认的beanName);
- 给BeanDefinition设置一些默认值,解析@Lazy等注解的值,存入到BeanDefinition中;
- checkCandidate:判断当前的BeanDefinition是否存在于Bean容器中,存在返回false,不存在返回true;
- 如果Bean容器中存在了这个BeanDefinition,就会进入isCompatible()方法;
- 首先判断是否兼容,是通过两个BeanDefinition的ReSource是否相同来进行判断是否兼容,兼容返回true,不兼容返回false;
- 返回false则注册BeanDefinition ,返回true,不注册 ;
标签:返回,spring,扫描,兼容,bean,是否,注解,class,BeanDefinition 来源: https://www.cnblogs.com/zhaozhitong/p/16544386.html