微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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,不注册 ;

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐