当前位置: 首页 > news >正文

网站建设推广员工资如何做市场推广方案

网站建设推广员工资,如何做市场推广方案,网站开发框架,房价即将迎来大涨前置知识 1 入口 DefaultListableBeanFactory#resolveDependency 2 每个依赖都有对应的DependencyDescriptor 3 自定绑定候选对象处理器AutowireCapableBeanFactory 注入处理 我们可以看到接口AutowireCapableBeanFactory中有两个方法。 第一个是单个注入: Null…

前置知识

1 入口 DefaultListableBeanFactory#resolveDependency
2 每个依赖都有对应的DependencyDescriptor
3 自定绑定候选对象处理器AutowireCapableBeanFactory

注入处理

我们可以看到接口AutowireCapableBeanFactory中有两个方法。
第一个是单个注入:

@Nullable
Object resolveDependency(DependencyDescriptor descriptor, @Nullable String requestingBeanName) throws BeansException;

还有一个是Set集合注入:

@Nullable
Object resolveDependency(DependencyDescriptor descriptor, @Nullable String requestingBeanName,
@Nullable Set<String> autowiredBeanNames, @Nullable TypeConverter typeConverter) throws BeansException;

我们可以看到它的实现关系:
在这里插入图片描述

下面这个代码从IOC中查找并注入一个Bean,依据这个区跟踪一下源码:

public class AnnotationDependencyInjectResolutionDemo {@Autowiredprivate Person person;public static void main(String[] args) {AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext();context.register(AnnotationDependencyInjectResolutionDemo.class);context.refresh();QualifierAnnotationDependencyInjectDemo bean = context.getBean(QualifierAnnotationDependencyInjectDemo.class);}}

我们直接断点看一下DefaultListableBeanFactory#resolveDependency
在这里插入图片描述

DependencyDescriptor参数里面的信息:
在这里插入图片描述
DependencyDescriptor 描述了我们要注入的目标的一些信息:
参考文章:https://blog.csdn.net/andy_zhang2007/article/details/88135669

// 保存所包装依赖(成员属性或者成员方法的某个参数)所在的声明类,
// 其实该信息在 field/methodParameter 中已经隐含
private final Class<?> declaringClass;
// 如果所包装依赖是成员方法的某个参数,则这里记录该成员方法的名称
@Nullable
private String methodName;
// 如果所包装的是成员方法的某个参数,则这里记录该参数的类型
@Nullable
private Class<?>[] parameterTypes;
// 如果所包装的是成员方法的某个参数,则这里记录该参数在该函数参数列表中的索引
private int parameterIndex;
//如果所包装的是成员属性,则这里记录该成员属性的名称
@Nullable
private String fieldName;
// 标识所包装依赖是否必要依赖
private final boolean required;
// 标识所包装依赖是否需要饥饿加载
private final boolean eager;
// 标识所包装依赖的嵌套级别
private int nestingLevel = 1;
// 标识所包装依赖的包含者类,通常和声明类是同一个
@Nullable
private Class<?> containingClass;
// 所包装依赖 ResolvableType 的缓存
@Nullable
private transient volatile ResolvableType resolvableType;
// 所包装依赖 TypeDescriptor 的缓存
@Nullable
private transient volatile TypeDescriptor typeDescriptor;

下面分类去跟踪注入过程。

依赖查处理过程

1 普通的字段

@Configuration
public class LookUpByAnnotationSingle {@AutowiredPersonHolder personHolder;@Single@BeanPersonHolder personHolder(){Person person = new Person();person.setId(777L);person.setName("yong");return new PersonHolder(person);}public static void main(String[] args) {AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext();context.register(LookUpByAnnotationSingle.class);context.refresh();Object bean = context.getBean("personHolder");context.close();}
}
  • 字段注入前面的判断都会跳过进入到下面这个方法
    在这里插入图片描述

  • 同样的我们只关注字段注入的核心流程,前面的条件都不满足来到这个方法findAutowireCandidates:

在这里插入图片描述

这个方法里面首先BeanFactoryUtils#beanNamesForTypeIncludingAncestors找到候选的Beans
在这里插入图片描述
候选的Bean是通过上面这个方法找到的,并且返回的时候将Bean对象放入到Map中。
在这里插入图片描述
然后我们如果我们多个bean,determineAutowireCandidate这个方法会决定一个Bean,决定的方式为如果使用了Primary就注入PrimaryBean否则Ordered根据这个接口定义(或者我们在Bean申明的时候标注了@Order注解)的优先级来寻找,数字越低优先级越高:
在这里插入图片描述
2 集合

@Autowired
private Collection<Person> personGroupAll;

集合注入核心逻辑会走到下面这个方法,这个方法返回的时候multipleBeans已经不为空了这个这个直接返回。
在这里插入图片描述
为什么上面可以直接返回呢,因为在resolveMultipleBeans方法中,判断了注入的类型如果是集合类型,也是走的一样的逻辑findAutowireCandidates找到候选的Bean进行返回。
在这里插入图片描述
3 懒加载

@Autowired
@Lazy
private Person person;

在懒注入的时候我们在这个方法已经有值了,所以逻辑在这一步就结束了,返回的是一个代理对象。
在这里插入图片描述
这个对象是cglib提升后的对象:
在这里插入图片描述

4 Optional

@Autowiredprivate Optional<Person> person;

核心逻辑是走下面

在这里插入图片描述
其实里面的逻辑是一样的,只是最后封装为Optional:
在这里插入图片描述

@Autowired注入过程

  • 元信息解析
  • 依赖查找
  • 依赖注入(字段方法)
    核心方法是AutowiredAnnotationBeanPostProcessor#AutowiredFieldElement#inject,在注入的过程中会先去处理依赖也就是上面的流程:
    参数bean是我们标注的类
    在这里插入图片描述

这个方法被谁调用呢?属性后置处理AutowiredAnnotationBeanPostProcessor#postProcessProperties,当我们用xml配置的时候那么这个时候PropertyValues存储的就是的配置值
在这里插入图片描述
从打断点来看postProcessProperties方法会先于set注入执行,也就是先注入元信息,然后再注入值。
下面这个方法是合并子类和父类的元信息,每个类都会进入这个方法如果没有父类就是自己的元信息,这个方法在postProcessProperties之前执行。
在这里插入图片描述
这里会去查找AutowiredAnnotationBeanPostProcessor#buildAutowiringMetadata
在这里插入图片描述

http://www.hkea.cn/news/580767/

相关文章:

  • 8网站建设做网站sem优化师是什么意思
  • 设计师个人网站怎么做百度优化培训
  • 广东海外建设监理有限公司官方网站2345网址导航是病毒吗
  • 深圳网站制作培训宁波网络营销公司
  • 网站建设方案书 模板长清区seo网络优化软件
  • 简述网站的推广策略产品设计
  • 商贸有限公司网站建设此网站服务器不在国内维护
  • 常州个人做网站制作小程序的软件
  • 郑州做网站公司dz论坛如何seo
  • 十堰商城网站建设网络营销seo优化
  • 小欢喜林磊儿什么网站做家教福州seo推广外包
  • 许昌网站开发博客营销
  • 做网站用jquery爱站网关键词挖掘
  • wordpress手动裁剪seo营销推广服务公司
  • 英文网站建设网站海南网站制作公司
  • 网页设计与网站建设主要内容软文营销的特点
  • 一起做网站17广州最新小组排名
  • 最专业的网站设计公司有哪些论坛企业推广
  • 单页网站怎么做外链个人网页
  • 宁波城乡住房建设局网站有效的网络推广
  • 网站建设 深圳销售crm客户管理系统
  • 高端网站开发设计站长之家字体
  • 免费网站建站工具购买域名的网站
  • 淘宝联盟怎么做网站百度网站提交
  • 前端做用vue做后台多还是做网站多青岛网站快速排名优化
  • 岳阳网站开发公司海淀区seo多少钱
  • 2017年做网站维护总结百度搜索软件
  • 南京网站建设公司点击器原理
  • 网站怎么编辑搜狗网站提交入口
  • 自建网站做外贸的流程广告推广方式