Scala equivalent of new HashSet(Collection)

南楼画角 提交于 2019-12-22 04:12:27

问题


What is the equivalent Scala constructor (to create an immutable HashSet) to the Java

new HashSet<T>(c)

where c is of type Collection<? extends T>?.

All I can find in the HashSet Object is apply.


回答1:


There are two parts to the answer. The first part is that Scala variable argument methods that take a T* are a sugaring over methods taking Seq[T]. You tell Scala to treat a Seq[T] as a list of arguments instead of a single argument using "seq : _*".

The second part is converting a Collection[T] to a Seq[T]. There's no general built in way to do in Scala's standard libraries just yet, but one very easy (if not necessarily efficient) way to do it is by calling toArray. Here's a complete example.

scala> val lst : java.util.Collection[String] = new java.util.ArrayList
lst: java.util.Collection[String] = []

scala> lst add "hello"
res0: Boolean = true

scala> lst add "world"
res1: Boolean = true

scala> Set(lst.toArray : _*)
res2: scala.collection.immutable.Set[java.lang.Object] = Set(hello, world)

Note the scala.Predef.Set and scala.collection.immutable.HashSet are synonyms.




回答2:


The most concise way to do this is probably to use the ++ operator:

import scala.collection.immutable.HashSet
val list = List(1,2,3)
val set = HashSet() ++ list


来源:https://stackoverflow.com/questions/674545/scala-equivalent-of-new-hashsetcollection

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!