gpt4 book ai didi

Scala 防止混合方法

转载 作者:行者123 更新时间:2023-12-02 04:40:14 25 4
gpt4 key购买 nike

我想创建以下特征:

trait IntSet[A] extends Traversable[A] { self: Product =>
def foreach[U](f: A => U): Unit
}

case class AProduct(a: List[Int], b: List[Int]) extends IntSet[Int] {
def foreach[U](f: Int => U): Unit = {
for(aa <- a; bb <- b) f(aa*bb)
}
}

AProduct(List(1, 5,6,7), List(2,3,4,5)).toString

返回

(2, 3, 4, 5, 10, 15, 20, 25, 12, 18, 24, 30, 14, 21, 28, 35)

但我不希望 case 类中的 toString 方法被可遍历对象之一覆盖!我该如何克服?

我希望最终输出为:

"AProduct(List(1, 5,6,7), List(2,3,4,5))"

如果可能的话,我想在 IntSet 中做一些不同于下面的事情:

override def toString = this.getClass().getName()+"("+self.productIterator.mkString(",")+")"

这行得通,但我真的不想重新发明轮子。

最佳答案

您不需要在AProduct 中实现IntSet。您可以像这样添加所有没有继承的方法:

case class AProduct(a: List[Int], b: List[Int])
object AProduct {
implicit class AProductIntSet(p: AProduct) extends Traversable[Int] {
def foreach[U](f: Int => U): Unit = {
for(aa <- p.a; bb <- p.b) f(aa*bb)
}
}
}

val ap = AProduct(List(1, 5,6,7), List(2,3,4,5))
// AProduct = AProduct(List(1, 5, 6, 7),List(2, 3, 4, 5))

ap.toString
// String = AProduct(List(1, 5, 6, 7),List(2, 3, 4, 5))

ap.map{_ + 1}
// Traversable[Int] = List(3, 4, 5, 6, 11, 16, 21, 26, 13, 19, 25, 31, 15, 22, 29, 36)

for{i <- AProduct(List(2), List(3, 5))} println(i)
// 6
// 10

关于Scala 防止混合方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20998866/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com