thisの記事で、implicitsを使用してScalaで型式をシミュレートする方法について説明しています。Scalaのtypeclassパターンの暗黙の定義の実行時コスト
私が間違っていない場合、再帰的インスタンス宣言の型クラスメソッド(Printer a => Printer (Option a)
)が使用されるたびに、新しいインスタンスが実行時に構築されます。ここにコードがあり、print
が使用されるたびに、新しいPrinter
インスタンスが実行時に作成されます。特定のタイプ(この場合はOption[Int]
)用に作成されたインスタンスを再利用する方法はありますか?
trait Printer[T] {
def print(t: T): String
}
object Printer {
implicit val intPrinter: Printer[Int] = new Printer[Int] {
def print(i: Int) = s"$i: Int"
}
implicit def optionPrinter[V](implicit pv: Printer[V]): Printer[Option[V]] =
new Printer[Option[V]] {
println("New Option Printer")
def print(ov: Option[V]) = ov match {
case None => "None"
case Some(v) => s"Option[${pv.print(v)}]"
}
}
}
object Main {
def print[T](t: T)(implicit p: Printer[T]) = p.print(t)
def main(args: Array[String]): Unit = {
val res3 = print(Option(1))
val res4 = print(Option(2))
println(s"res3: ${res3}")
println(s"res4: ${res4}")
}
}
// New Option Printer
// New Option Printer
// res3: Option[1: Int]
// res4: Option[2: Int]