今天在看java中HashMap类的源码时,看到HashMap中用来记录键值对的Entry类是静态的。
static class Entry<K,V> implements Map.Entry<K,V> {
}
据我所知,类的静态成员对于类的所有实例只有一个值。这种现象如何适用于静态嵌套类的情况。我还阅读了 StackOverFlow 中的一些讨论,无法准确指出。下面是一些解释的链接,说明为什么 Entry 类是静态的。
今天在看java中HashMap类的源码时,看到HashMap中用来记录键值对的Entry类是静态的。
static class Entry<K,V> implements Map.Entry<K,V> {
}
据我所知,类的静态成员对于类的所有实例只有一个值。这种现象如何适用于静态嵌套类的情况。我还阅读了 StackOverFlow 中的一些讨论,无法准确指出。下面是一些解释的链接,说明为什么 Entry 类是静态的。
据我所知,类的静态成员对于类的所有实例只有一个值。
正确的。
这种现象如何适用于静态嵌套类?
它不是。静态嵌套类没有隐含的周围对象,因此它无法访问封闭类的非静态成员。
您发布的链接包含几个答案,所有答案都与上述相同。
这实际上只是出于组织目的。静态嵌套类的行为类似于包中的顶级类。在这种情况下,Entry 类与 HashMap 直接相关,因此嵌套它而不污染主包是有意义的。
我建议阅读 Oracle 教程:http ://docs.oracle.com/javase/tutorial/java/javaOO/nested.html