其他分享
首页 > 其他分享> > spring 中bean 的扫描过程总结

spring 中bean 的扫描过程总结

作者:互联网

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

标签:返回,spring,扫描,兼容,bean,是否,注解,class,BeanDefinition
来源: https://www.cnblogs.com/zhaozhitong/p/16544386.html