备战面试日记(4.2.9)- (框架.Spring【九】之Spring IOC 源码initMessageSource())

本人本科毕业,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依托SpringResourceLoader加载Resource资源,功能更加强大,同时支持.properties文件.xml文件
      • 缓存时间
        • ResourceBundleMessageSource主要利用ResourceBundle.Control 实现简单的自动重载。
        • ReloadResourceBundleMessageSource每次加载资源都会记录每个资源的加载时间点,在缓存资源过期后会再次比较文件的修改时间,如果不变则不需要重新加载,同时刷新本次加载时间点。
      • 编码方式
        • ResourceBundleMessageSource可以统一指定默认的文件编码方式 。
        • ReloadResourceBundleMessageSource不仅可以指定统一的默认编码方式,也同时支持为每个文件单独制定编码方式。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

舍其小伙伴

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值