Spring启动时DefaultNamespaceHandlerResolver初始化
最近在看spring源码 自定义解析标签部分,想到了一个问题,名命空间是如何出初始化的,于是查看源码,
进入构造函数,此时,handlerMappings为空,
在断点到namespaceHandlerResolver,的时候,发现DefaultNamespaceHandlerResolver对应的handlerMappings存在了值,
namespaceHandlerResolver
在使用DefaultNamespaceHandlerResolver构造函数的时候,并未发现初始化handleMapping
很奇怪啊,构造函数的时候,明明没有初始化handlerMapping
那么handlerMapping到底是什么时候初始化的呢?
在观察DefaultNamespaceHandlerResolver中,有段代码值得我们去注意:getHandlerMapping方法,此方法是将HandlerMapping初始化的代码,肯定是哪里去调用了该方法,此方法,进行了双重校验,并加锁,
我们此时将断点打到第163行和173行可以进入这个方法,(实验证明,断点在154,进不了这个方法)
因为handlerMapping为私有参数,getHandlerMapping私有方法,所以,外部类是调用不到该参数的,发现,DefaultNamespaceHandlerResolver 在toString方法中,调用了getHandlerMapping方法,
那么toString是什么调用的呢???
查询网上其他文章得知:在debug模式的时候,构造函数执行完毕后IDE调用了该对象的toString()方法。
注:此处之所以开始未能发现何时初始化了handlerMappings,是因为IntelliJ IDEA自动调用的方法是不会进入相应断点的。其实可以测试下,如果中间没有断点的情况下,handlerMappings就没有值。
ok,到此为止,