JDK Hashmap源代码 - 匿名内部类和抽象实例化?

Dan*_*anK 4 java anonymous-inner-class instantiation hashmap

问题

我试图了解Sun如何实现HashMap类的entrySet,keySet和values方法,但我遇到的代码对我来说没有意义.

我从概念上理解这些方法返回的视图直接链接到HashMap中的map.entry列表,并且它们使用自己的迭代器(引用中央HashMap迭代器)来完成大部分工作.我的问题在于理解这些视图究竟是如何被实例化的(因为它们不是副本,而是位于实际HashMap列表之上的东西).

参考

我正在查看本网站上的源代码:http://developer.classpath.org/doc/java/util/HashMap-source.html

这是给我带来麻烦的一个片段:

 157:   private transient Set<Map.Entry<K, V>> entries;

 594:   public Set<Map.Entry<K, V>> entrySet()
 595:   {
 596:     if (entries == null)
 597:       // Create an AbstractSet with custom implementations of those methods
 598:       // that can be overridden easily and efficiently.
 599:       entries = new AbstractSet<Map.Entry<K, V>>()
 600:       {
 601:         public int size()
 602:         {
 603:           return size;
 604:         }
 605: 
 606:         public Iterator<Map.Entry<K, V>> iterator()
 607:         {
 608:           // Cannot create the iterator directly, because of LinkedHashMap.
 609:           return HashMap.this.iterator(ENTRIES);
 610:         }
 611: 
 612:         public void clear()
 613:         {
 614:           HashMap.this.clear();
 615:         }
 616: 
 617:         public boolean contains(Object o)
 618:         {
 619:           return getEntry(o) != null;
 620:         }
 621: 
 622:         public boolean remove(Object o)
 623:         {
 624:           HashEntry<K, V> e = getEntry(o);
 625:           if (e != null)
 626:             {
 627:               HashMap.this.remove(e.key);
 628:               return true;
 629:             }
 630:           return false;
 631:         }
 632:       };
 633:     return entries;
 634:   }
Run Code Online (Sandbox Code Playgroud)

问题

  • 在第599行,此代码实例化AbstractSet类.这怎么可能?我试图自己重新创建它,但我得到了预期的编译错误.

  • 我假设第601,606,612,617和622行中的公共方法是匿名内部类?我之前从未使用过这个功能所以我不知道它是如何工作的,我在网上找到的唯一例子相当简单(主要涉及Swing).我必须假设第599行与匿名类直接相关,但我不遵循如何.

如果有人能向我解释,我将非常感激!谢谢!

Jon*_*eet 7

在第599行,此代码实例化AbstractSet类.这怎么可能?

通过一个匿名的内部阶级.它正在创建一个具体(但未命名)的子类AbstractSet.您可以对接口执行相同的操作.例如:

Runnable runnable = new Runnable() {
    @Override public void run() {
        // Put some code in here...
    }
};
Run Code Online (Sandbox Code Playgroud)

我假设第601,606,612,617和622行中的公共方法是匿名内部类?

不,整个班级都是匿名的内部班级.这些正在实现抽象方法AbstractSet.

我建议你阅读匿名课程Java教程页面.