scala java 隐式转换_使用JavaConversions在Java和Scala集合之间进行隐式转换

这篇博客讨论了在Scala中如何使用JavaConverters进行Java和Scala集合之间的隐式转换。文章通过示例展示了在转换过程中遇到的问题和解决方案,强调了不推荐使用JavaConversions的原因,并提供了正确的转换方法。
摘要由CSDN通过智能技术生成

小编典典

他们说尝试使用JavaConverters,因为不推荐使用JavaConversions。

scala> import collection.JavaConverters._

import collection.JavaConverters._

scala> def mergeMaps[A, B](ms: Set[Map[A, B]])(f: (B, B) => B): Map[A, B] =

| (new java.util.HashMap[A, B] /: (for (m

| case (a, kv) => a + (if (a.contains(kv._1)) kv._1 -> f(a(kv._1), kv._2) else kv) }

:16: error: value contains is not a member of java.util.HashMap[A,B]

case (a, kv) => a + (if (a.contains(kv._1)) kv._1 -> f(a(kv._1), kv._2) else kv) }

^

:16: error: java.util.HashMap[A,B] does not take parameters

case (a, kv) => a + (if (a.contains(kv._1)) kv._1 -> f(a(kv._1), kv._2) else kv) }

^

:16: error: type mismatch;

found : (A, B)

required: String

case (a, kv) => a + (if (a.contains(kv._1)) kv._1 -> f(a(kv._1), kv._2) else kv) }

^

:15: error: type mismatch;

found : java.util.HashMap[A,B]

required: Map[A,B]

(new java.util.HashMap[A, B] /: (for (m

^

scala> def mergeMaps[A, B](ms: Set[Map[A, B]])(f: (B, B) => B): Map[A, B] =

| (new java.util.HashMap[A, B].asScala /: (for (m

| case (a, kv) => a + (if (a.contains(kv._1)) kv._1 -> f(a(kv._1), kv._2) else kv) }

:15: error: type mismatch;

found : scala.collection.mutable.Map[A,B]

required: scala.collection.immutable.Map[A,B]

(new java.util.HashMap[A, B].asScala /: (for (m

^

scala> def mergeMaps[A, B](ms: Set[Map[A, B]])(f: (B, B) => B): Map[A, B] =

| (new java.util.HashMap[A, B].asScala.toMap /: (for (m

| case (a, kv) => a + (if (a.contains(kv._1)) kv._1 -> f(a(kv._1), kv._2) else kv) }

mergeMaps: [A, B](ms: Set[Map[A,B]])(f: (B, B) => B)Map[A,B]

也许要说明为什么不推荐使用它:

scala> def mergeMaps[A, B](ms: Set[Map[A, B]])(f: (B, B) => B): Map[A, B] =

| (new java.util.HashMap[A, B] /: (for (m

| case (a, kv) => a + (if (a.contains(kv._1)) kv._1 -> f(a(kv._1), kv._2) else kv) }

:19: error: type mismatch;

found : scala.collection.mutable.Map[A,B]

required: java.util.HashMap[A,B]

case (a, kv) => a + (if (a.contains(kv._1)) kv._1 -> f(a(kv._1), kv._2) else kv) }

^

:18: error: type mismatch;

found : java.util.HashMap[A,B]

required: Map[A,B]

(new java.util.HashMap[A, B] /: (for (m

^

注意for理解会产生一对对。

scala> def mergeMaps[A, B](ms: Set[Map[A, B]])(f: (B, B) => B) = for (m

mergeMaps: [A, B](ms: Set[Map[A,B]])(f: (B, B) => B)scala.collection.immutable.Set[(A, B)]

显然,推论既无法完成转换又无法找出操作类型。

有时将表达式分开会有助于推理,但不能在此进行。

scala> def mergeMaps[A, B](ms: Set[Map[A, B]])(f: (B, B) => B): Map[A, B] = {

| val ss = for (m

| (new java.util.HashMap[A, B] /: ss) {

| case (a, kv) => a + (if (a.contains(kv._1)) kv._1 -> f(a(kv._1), kv._2) else kv) }

| }

2020-11-30

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值
>