scala - 丰富一个内部类

标签 scala inner-classes implicit enrich-my-library

我想为内部类实现 enrich-my-library 模式,该模式适用于外部类的任何实例。像这样:

class Outer {
  class Inner(val x: Option[Inner] = None) {
    def test(y: Inner) {}
  }
}

implicit class ExtInner(inner: Outer#Inner) {
  def get = inner.x.get
}

val outer = new Outer
val inner = new outer.Inner(Some(new outer.Inner))
inner.test(inner.get)

由于类型不匹配,此代码将无法编译:get 返回类型为 Outer#Inner 的对象,但 test 期望 外.内

我有两种方法让它工作,但都涉及使用 asInstanceOf,我想避免。第一个是简单地将 get 的结果转换为 outer.Inner:

inner.test(inner.get.asInstanceOf[outer.Inner]) 

第二个更通用一些,在 ExtInner 中进行转换:

implicit class ExtInner[T <: Outer#Inner](inner: T) {
  def get = inner.x.get.asInstanceOf[T]
}

是否有更好的方法来丰富内部类,从而无需进行转换?

最佳答案

怎么样:

object Test extends App {
  class Outer {
    class Inner(val x: Option[Inner] = None) {
      def test(y: Inner) { println(s"$toString testing $y") }
    }
    implicit class ExtInner(val inner: Inner) {
      def get = inner.x.get
    }
  }

  val outer = new Outer
  val inner = new outer.Inner(Some(new outer.Inner))
  import outer._
  inner.test(inner.get)
}

或者只是增强外部的内部:

  implicit class ExtInner(val inner: outer.Inner) {
    def get = inner.x.get
  }

此外,我感觉您可以通过这种方式调用该方法,但它不会推断单例类型参数 outer.type 以调用隐式。

  implicit class ExtInner[A <: Outer with Singleton](val inner: A#Inner) {
    def get: A#Inner = inner.x.get
  }
  inner.test(ExtInner[outer.type](inner).get)

关于scala - 丰富一个内部类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16977730/

相关文章:

scala - 如何在 Scala 中检测键盘快捷键,如 CTRL+S

java - 在java中将java映射转换为scala不可变映射

java - 是否可以使用 Java 反射创建内部类的实例?

java - 如何访问匿名对象内声明的字段?

在方法调用后定义隐式 val 时,Scala 隐式参数为 null

scala - 在类中包装 akka actor 会导致内存泄漏吗?

python - 在另一个类中定义一个类并调用父方法

scala - 限制组合隐式参数和 View /上下文边界的原因是什么?

scala - 关键字 'implicit' 放在 lambda 表达式参数前面是什么意思?

Scala Value 类和 Mockito Matchers 不一起玩