Scala奇怪的代码无法理解:Visitor [String]⇒

时间:2018-07-07 11:55:47

标签: scala

我对Scala还是很陌生,所以请不要投票给我。表达式this: Visitor[Double] ⇒是什么意思?对我来说,它看起来像是不完整的代码。我试图在Google上找到这个概念,但是由于我不知道这个概念名称,因此无法找到它。

import scala.language.higherKinds

trait Expressions {

  trait TVisitor[T] {
    def visitConstant(v: Double): T
  }
  type Visitor[T] <: TVisitor[T]

  trait Expression {
    def accept[T](visitor: Visitor[T]): T
  }

  class Constant(val v: Double) extends Expression {
    def accept[T](visitor: Visitor[T]): T = visitor.visitConstant(v)
  }

  trait EvalVisitor extends TVisitor[Double] {
    def visitConstant(v: Double): Double = v
  }
}

trait AddExpressions extends Expressions {
  class Add(val l: Expression, val r: Expression) extends Expression {
    def accept[T](visitor: Visitor[T]): T = visitor.visitAdd(l, r)
  }

  trait TVisitor[T] extends super.TVisitor[T] {
    def visitAdd(l: Expression, r: Expression): T
  }
  type Visitor[T] <: TVisitor[T]

  trait EvalVisitor extends super.EvalVisitor with TVisitor[Double] {
    this: Visitor[Double] ⇒
    def visitAdd(l: Expression, r: Expression): Double =
      l.accept(this) + r.accept(this)
  }
}

trait ExtendedExpressions extends AddExpressions with MultExpressions {
  type Visitor[T] = TVisitor[T]
  trait TVisitor[T]
      extends super[AddExpressions].TVisitor[T]
      with super[MultExpressions].TVisitor[T]
  object EvalVisitor
      extends super[AddExpressions].EvalVisitor
      with super[MultExpressions].EvalVisitor
      with TVisitor[Double] {
    this: Visitor[Double] ⇒
  }
}

trait PrefixNotationForExpressions extends ExtendedExpressions {
  object PrefixNotationVisitor extends super.TVisitor[String] {
    this: Visitor[String] ⇒
    def visitConstant(v: Double): String = v.toString + " "
    def visitAdd(l: Expression, r: Expression): String =
      "+ " + l.accept(this) + r.accept(this)
    def visitMult(l: Expression, r: Expression): String =
      "* " + l.accept(this) + r.accept(this)
  }
}

1 个答案:

答案 0 :(得分:3)

this: Visitor[Double] ⇒在Scala中称为Self Type。可以阅读here

在此示例中,这意味着实现PrefixNotiationForExpressions的任何类也必须实现Visitor[String]

在Java中没有等效于自我类型。关于它们的最常见问题是,为什么不在特征的extends子句中声明类型。以下StackOverflow参考在解释这一方面做得非常好:What is the difference between self-types and trait subclasses?。核心区别归结为我们代表的是“是”关系还是“需要”关系。