[英]Creating instances of static nested class within that
为什么静态内部类Node允许类中包含new Node[R]
字段,为什么这里没有发生无限递归?
public class TrieST<Value> {
private static final int R = 256; // extended ASCII
private Node root; // root of trie
private int N; // number of keys in trie
// R-way trie node
private static class Node {
private Object val;
private Node[] next = new Node[R];
}
...
}
x =新的Node(); //在包含的类中很好,但是尚不清楚静态嵌套Node类中的new Node[R]
。
线
private Node[] next = new Node[R];
声明并初始化next
一个作为数组引用的字段(您应将Node[]
读为“ Node
array”)。 表达式new Node[R]
不创建任何节点,而是创建一个节点数组。 因此,没有递归。
如果您有一个诸如
private Node someNode = new Node();
那么实际上您将具有递归,因为每个节点都将创建另一个节点,该节点将创建下一个节点,依此类推。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.