Scala入门笔记

这篇博客介绍了Scala的使用,包括简单的流程控制和trait的混入。通过一个有理数构造的例子展示了如何在Scala中利用trait来扩展子类功能,同时解释了trait混入的规则和顺序。
摘要由CSDN通过智能技术生成

一个构建有理数的scala例子

class Rational(n: Int, d: Int) {
  require(d!=0)
  private val g = gcd(n.abs, d.abs)  //最大公约数
  val numer: Int = n / g
  val denom: Int = d / g


  def this(n: Int) = this(n, 1)

  override def toString = numer + "/" + denom

  def add(that: Rational): Rational =
    new Rational(numer*that.denom+that.numer*denom,
      denom * that.denom)

  def +(that: Rational): Rational = add(that)

  def mul(that: Rational): Rational =
    new Rational(numer*that.numer, denom*that.denom)

  def *
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值