Scala之旅(TOUR OF SCALA)——通过混合组成类(CLASS COMPOSITION WITH MIXINS)

混合就是被用来组合成类的特征。

abstract class A {
  val message: String
}
class B extends A {
  val message = "I'm an instance of class B"
}
trait C extends A {
  def loudMessage = message.toUpperCase()
}
class D extends B with C

val d = new D
println(d.message)  // I'm an instance of class B
println(d.loudMessage)  // I'M AN INSTANCE OF CLASS B

D 有一个父类 B 和一个混合 C。类只能有一个父类但是可以有很多混合(分别使用关键字 extendswith)。混合和父类可能有相同的父类。

现在,让我们看一个使用抽象类更有趣的例子:

abstract class AbsIterator {
  type T
  def hasNext: Boolean
  def next(): T
}

上面的例子中的类有一个抽象的类型 T 和标准的迭代器方法。

下一步,我们将实现一个具体的类(所有的抽象成员 ThasNextnext 都会被实现):

class StringIterator(s: String) extends AbsIterator {
  type T = Char
  private var i = 0
  def hasNext = i < s.length
  def next() = {
    val ch = s charAt i
    i += 1
    ch
  }
}

实现类 StringIterator 需要一个字符串参数用来迭代字符。

现在,让我们创建一个特征也继承 AbsIterator

trait RichIterator extends AbsIterator {
  def foreach(f: T => Unit): Unit = while (hasNext) f(next())
}

因为 RichIterator 是特征,所以不需要实现抽象类 AbsIterator 中的方法。

现在,我们将 StringIterator 类和 RichIterator 特征的功能组合成一个简单的类中。

object StringIteratorTest extends App {
  class RichStringIter extends StringIterator("Scala") with RichIterator
  val richStringIter = new RichStringIter
  richStringIter foreach println
}

新的类 RichStringIter 父类为 StringIterator 还混合了 RichIterator 特征。

这是我们使用简单的继承不能实现这种程度的复杂功能。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值