Spring源码之SimpleAliasRegistry解读(一)

Spring源码之SimpleAliasRegistry解读(一)java

阅读spring源码中org.springframework.core.SimpleAliasRegistry类时发现该类主要是使用map做为alias的缓存,并对接口AliasRegistry进行实现。spring

在阅读该源码中对hasAlias(String name, String alias);方法产生了疑惑。源码注释中解释该方法的做用是:肯定给定的名称是否已注册了给定的别名。缓存

该方法源码以下:ui

public boolean hasAlias(String name, String alias) { //遍历Map for (Map.Entry<String, String> entry : this.aliasMap.entrySet()) { //获取值 String registeredName = entry.getValue(); //判断该值与传入的name是否相等 if (registeredName.equals(name)) { //若是相等,则获取该值对应得键 String registeredAlias = entry.getKey(); //判断该键与传入的别名是否相等,若是相等则返回true //若是不想等,则将该键与传入的别名做为此方法的参数,进行递归调用 return (registeredAlias.equals(alias) || hasAlias(registeredAlias, alias)); } } return false; }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16

以及使用到的成员变量是:this

private final Map<String, String> aliasMap = new ConcurrentHashMap<String, String>(16);
  • 1
  • 1

为了分析我为每行添加了注释,刚开始使我不能理解的是return (registeredAlias.equals(alias) || hasAlias(registeredAlias, alias)); 这行代码。为何递归调用hasAlias方法时传入的第一个参数不是name。spa

通过分析,发现设计该map时,不是为了存放单一的键值对。.net

我想到了两种假设:设计

假设一:map是存放一个相似于倒着的树。name是做为根节点而存在的,alias是做为根节点下的子节点。可是又出现一个问题,按hasAlias这个方法来循环遍历是永远也遍历不到全部父节点下的第二个子节点,因此这个假设被否认。code

假设二:一条节点链。name是该链的头,alias是该链除了头以外的其余节点,只要传入该方法的alias是该链的除头部以外的某一节点,返回的就是true,和方法给定的解释正好吻合。blog

若是解释的不对,请读者朋友留言告知,谢谢!

相关文章
相关标签/搜索