本人本科毕业,21届毕业生,一年工作经验,简历专业技能如下,现根据简历,并根据所学知识复习准备面试。
记录日期:2022.1.4
大部分知识点只做大致介绍,具体内容根据推荐博文链接进行详细复习。
文章目录
框架原理 - Spring(九)之Spring IOC 源码initMessageSource()
AbstractApplicationContext#initMessageSource()
这是针对于国际化问题的MessageSource
。
准备出国编程的小伙伴了解一下,我应该是用不到的=。=…
// 初始化消息源。如果在此上下文中未定义MessageSource,请使用父级。
protected void initMessageSource() {
// 获取Bean工厂,一般是DefaultListBeanFactory
ConfigurableListableBeanFactory beanFactory = getBeanFactory();
// 首先判断容器中是否存在beanName为"messageSource"的bean实例
if (beanFactory.containsLocalBean(MESSAGE_SOURCE_BEAN_NAME)) {
// 如果有,则从Bean工厂得到这个bean对象
this.messageSource = beanFactory.getBean(MESSAGE_SOURCE_BEAN_NAME, MessageSource.class);
// 【注释翻译】使MessageSource知道父MessageSource
// 当父类Bean工厂不为空 并且 这个bean对象是HierarchicalMessageSource类型
if (this.parent != null && this.messageSource instanceof HierarchicalMessageSource) {
//为HierarchicalMessageSource的实现类
HierarchicalMessageSource hms = (HierarchicalMessageSource) this.messageSource;
//设置父类MessageSource,此处设置内部的parent messageSource
if (hms.getParentMessageSource() == null) {
// 【注释翻译】仅当尚未注册父MessageSource时,才将父上下文设置为父MessageSource
hms.setParentMessageSource(getInternalParentMessageSource());
}
}
if (logger.isTraceEnabled()) {
logger.trace("Using MessageSource [" + this.messageSource + "]");
}
}
else {
// 【注释翻译】使用空MessageSource可以接受getMessage调用
// 如果没有xml文件定义信息源对象,新建DelegatingMessageSource类作为messageSource的Bean
// 因为DelegatingMessageSource类实现了HierarchicalMessageSource接口,而这个接口继承了MessageSource这个类
// 因此实现了这个接口的类,都是MessageSource的子类,因此DelegatingMessageSource也是一个MessageSource
DelegatingMessageSource dms = new DelegatingMessageSource();
dms.setParentMessageSource(getInternalParentMessageSource());
this.messageSource = dms;
//将这个messageSource实例注册到Bean工厂中
beanFactory.registerSingleton(MESSAGE_SOURCE_BEAN_NAME, this.messageSource);
if (logger.isTraceEnabled()) {
logger.trace("No '" + MESSAGE_SOURCE_BEAN_NAME + "' bean, using [" + this.messageSource + "]");
}
}
}
MessageSource类图
对它们不同实现类做一下简单的说明:
- MessageSource:抽象化的消息接口。
- HierarchicalMessageSource:分层的消息源接口,可获取父消息源。
- MessageSourceSupport:帮助消息源解析的抽象类,通过指定“消息格式化组件
MessageFormat
格式化消息。 - DelegatingMessageSource: 消息源解析委派类(用户未指定时,SpringContext默认使用当前类),功能比较简单:将字符串和参数数组格式化为一个消息字符串。
- AbstractMessageSource:支持‘配置文件’的方式国际化资源 的 抽象类,内部提供一个与区域设置无关的公共消息配置文件,消息代码为关键字。
- StaticMessageSource:主要用于程序测试,它允许通过编程的方式提供国际化信息。
- ResourceBundleMessageSource:该实现类允许用户通过beanName指定一个资源名(包括类路径的全限定资源名),或通过beanNames指定一组资源名。不同的区域获取加载资源文件,达到国际化信息的目的。
- ReloadableResourceBundleMessageSource:这个类的功能比较强大,主要就是将消息串、参数数组格式化成字符串。
- 同
ResourceBundleMessageSource
区别在于这几点:- 加载资源类型及方式
ResourceBundleMessageSource
依托JDK自带ResourceBundle
加载资源,支持绝对路径和工程路径,支持文件为.class文件
和.properties文件
。ReloadResourceBundleMessageSource
依托Spring
的ResourceLoader
加载Resource
资源,功能更加强大,同时支持.properties文件
和.xml文件
。
- 缓存时间
ResourceBundleMessageSource
主要利用ResourceBundle.Control
实现简单的自动重载。ReloadResourceBundleMessageSource
每次加载资源都会记录每个资源的加载时间点,在缓存资源过期后会再次比较文件的修改时间,如果不变则不需要重新加载,同时刷新本次加载时间点。
- 编码方式
ResourceBundleMessageSource
可以统一指定默认的文件编码方式 。ReloadResourceBundleMessageSource
不仅可以指定统一的默认编码方式,也同时支持为每个文件单独制定编码方式。
- 加载资源类型及方式
- 同