1

我有以下课程:

public abstract class Map {
    protected PriorityQueue<Node> openNodes;
}

我的实现目前是这样工作的:

public Map() {
        PriorityQueue<Node> openNodes = new PriorityQueue<Node>((Node node1, Node node2) -> Integer.compare(node1.getFinalCost(), node2.getFinalCost()));
    }

但是,我也想使用这样的实现:

public Map() {
        PriorityQueue<Node> openNodes = new PriorityQueue<Node>((Node node1, Node node2) -> Integer.compare(node1.getHeuristicCost(), node2.getHeuristicCost()));
    }

有没有办法将我的 Node 类的heuristicCostfinalCost字段传递给构造函数来实现这些不同的行为?像这样的东西:

public Map(*fieldName*) {
        PriorityQueue<Node> openNodes = new PriorityQueue<Node>((Node node1, Node node2) -> Integer.compare(node1.get*fieldName*(), node2.get*fieldName*()));
    }

如果没有,您能否提出一个解决方案来实现这一目标?

4

1 回答 1

6

您可以使用以下方法从方法引用创建比较器Comparator.comparingInt

public Map(ToIntFunction<Node> compareBy) {
    this.openNodes = new PriorityQueue<>(Comparator.comparingInt(compareBy));
}

然后你可以写new Map(Node::getFinalCost)new Map(Node::getHeuristicCost)

于 2020-12-30T23:30:13.567 回答