默认标签的解析是在parseDefaultElement之中进行的
分别对4种不同标签做了不同处理,最为核心的是bean标签。
(1)BeanDefinitionHolder bdHolder = delegate.parseBeanDefinitionElement(ele);
委托BeanDefinitionDelegate类的parseBeanDefinitionElement方法进行元素解析。
上面的代码说明默认bean名称是id,如果没有id选择别名的第一个作为bean的名称
checkNameUniqueness检测名称的唯一性。
这边我刚开始看的时候有个疑问,如果id为空,name也为空的时候是怎么处理?
看下后面部分
如果name依然为空,那么会使用spring的默认规则进行生成beanName。
但是这个为什么会发生在checkNameUniqueness之后呢?
这个就不清楚为什么了直接将空值传进去吗 ??
其实是空字符串不会返回this.error(),所以每次加个空值进去也没有什么关系。
总结一下步骤:
1.提取元素中的id和name属性
2.进一步解析其他所有属性并统一封装至GenericBeanDefinition类型的实例中
3.如果检测到bean没有指定beanName,那么使用默认规则为此Bean生产beanName
4.将获取到的信息封装到BeanDifinitionHolder的实例中
详细看下第二步