Cra*_*lin 6 generics types scala
我正在尝试编写一个方法,该方法采用Map [K,Collection [V]]并将其转换为具有不同类型Collection的值的地图.该方法采用"multimap"和构建新集合的构建器.我这样使用它:
val multimap = new java.util.HashMap[Int, java.util.List[String]]
multimap.put(1, Arrays.asList("One"))
multimap.put(2, Arrays.asList("Two", "Three"))
val mapOfLists: java.util.Map[Int, java.util.Set[String]] =
asMap(multimap, Builder.SET)
Run Code Online (Sandbox Code Playgroud)
这是构建器的样子:
trait Builder[C[_] <: java.util.Collection[_]]
{
def create[V]: C[V]
}
object Builder
{
val SET = new Builder[java.util.Set]()
{
def create[V]: java.util.Set[V] = new java.util.HashSet[V]
}
}
Run Code Online (Sandbox Code Playgroud)
这是asMap()的实现.它有效,但我不明白 - 为什么我需要在最后输入类型?
def asMap[K, V, C[_] <: java.util.Collection[_]](
multimap: java.util.Map[K, _ <: java.util.Collection[V]], builder: Builder[C]): java.util.Map[K, C[V]] =
{
val result = new java.util.HashMap[K, C[V]]
val iterator: Iterator[K] = multimap.keySet.iterator
while (iterator.hasNext)
{
val key = iterator.next
val collection: C[V] = builder.create[V]
collection.asInstanceOf[java.util.Collection[V]].addAll(multimap.get(key))
result.put(key, collection)
}
result
}
Run Code Online (Sandbox Code Playgroud)
没有类型的情况我得到这个错误:
[ERROR] error: type mismatch;
[INFO] found : java.util.Collection[V]
[INFO] required: java.util.Collection[_ <: _$2] where type _$2
[INFO] collection.addAll(multimap.get(key))
Run Code Online (Sandbox Code Playgroud)
您不小心创建了存在类型而不是类型构造函数.一个有效的类型构造函数将是C[X] <: Collection[X|您需要更改Builder为
trait Builder[C[X] <: Collection[X]] {
def create[V]: C[V]
}
Run Code Online (Sandbox Code Playgroud)
和签名asMap来
def asMap[K, V, C[X] <: Collection[X]](multimap: Map[K, _ <: Collection[V]],
builder: Builder[C]): Map[K, C[V]]
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1095 次 |
| 最近记录: |