问题描述
我正在尝试使用递归下降解析方法和访问者模式构建一个编译器,以使用 Java 进行语义检查。让我困惑的是使用访问者模式,我们必须创建不同的子类型。但是,Java 不通过引用传递。这让我无法为每个语义记录找到正确的子类型。这是我正在尝试实施的
Node node = new ExprNode();
changeNodeType(node);
public void changeNodeType(Node node) {
node = new AddOpNode();
}
然后最终我的 Node 类型将以 AddOpNode() 结束。有什么办法可以让我最终在 Java 中实现它吗?
解决方法
你可以只返回新的节点类型并在函数之外分配它。
Node node = new ExprNode();
node = changeNodeType();
public Node changeNodeType() {
return new AddOpNode();
}