不久前,我为一个导航图编写了一个编辑器,用于表示建筑物内部(以及建筑物之间)的路径。它被存储在一个Graph类中。
例如,边缘存储在每个楼层的一个集合中,加上楼层之间的一个集合。
要绘制它们(仅当前楼层)或将它们保存到磁盘(所有),我需要从外部访问它们。为此,我实现了像callWithAllEdges和callWithAllEdgesIn这样的方法,后者接受一个参数来指定发言权。
这些方法需要一个functor (至少我是这么叫的),然后用边调用它。
下面是绘制一个楼层的边缘的样子:
graph.callWithAllEdgesIn(id, new Functor<Edge>() {
public void call(Edge e) {
drawEdge(g,e);
}
});
当然,这有点冗长。可能是java的问题,而不是我的解决方案,我不知道。
另一种方法是创建一个方法,将对所有需要的边的引用放到一个新的集合中,然后迭代该集合。不过,在我看来是不对的。
我的问题是:我怎样才能更好地解决这个问题?
发布于 2012-08-31 03:55:33
你目前的设计是完全合理的。另一种选择是提供一个Iterable/Iterator。这样你就不需要把所有的东西都复制到一个新的列表中,而是可以懒惰地遍历你的内部列表。
https://stackoverflow.com/questions/12202985
复制相似问题