作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
scala.collection.immutable.Queue
的enqueue
函数被重载。
def enqueue[B >: A](elem: B]): Queue[B]
def enqueue[B >: A](iter: Iterable[B]): Queue[B]
第一个签名允许您将单个项目添加到队列中,而后者允许您添加多个项目。
我正在研究一种图形搜索算法,并使用队列来跟踪我到目前为止所遍历的路径 (List[Node]
)。但是当我尝试对路径进行排队时,编译器假定我想使用具有可迭代签名的函数并抛出错误。
val path = List(Node(0), Node(1), Node(4))
val q: Queue[List[Node]] = Queue[List[Node]]().enqueue(path)
// Expression of type Queue[Product with Serializable] does not conform to expected type Queue[List[Node]]
我可以通过将路径包装在另一个列表中来解决这个问题,但这是强制的并且不太清楚。
val q: Queue[List[Node]] = Queue[List[Node]]().enqueue(List(path))
// compiles
有更好的方法吗?
编辑我还注意到 :+
运算符仅用于对单个元素进行排队,我更喜欢它。
val q: Queue[List[Node]] = Queue[List[Node]]() :+ path
最佳答案
enqueue
的类型参数可以更明确:
q.enqueue[List[Node]](path)
应该适合你。
关于scala - 如何将元素排入可迭代队列,例如队列[列表[节点]]?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32417278/
我是一名优秀的程序员,十分优秀!