idea debug的时候会开启一个线程之行 toString,所以我们一般不要在toString 做什么操作。
目前在读spring解析自定义标签的源。
解析过程中在XmlBeanDefinitionReader对象中的createDefaultNamespaceHandlerResolver()方法中需要生成DefaultNamespaceHandlerResolver对象,采用的是构造方法new DefaultNamespaceHandlerResolver(getResourceLoader().getClassLoader());这个构造方法只是将DefaultNamespaceHandlerResolver的属性handlerMappingsLocation设置了初始值META-INF/spring.handlers,以及设置了属性classLoader的值,但是并没有对属性private volatile Map handlerMappings进行操作,但是构造完的DefaultNamespaceHandlerResolver对象的属性handlerMappings却有值,是把spring.handlers里的内容以key-value的形式保存的。
那么问题来了,handlerMappings属性是在什么时候赋值的?
答案链接点击打开链接