Scala 的例题:银行账户钱存取功能

private 方法

Scala 复制代码
​
package Test22
// 银行账户
class BankAccount(private var balance:Int){
  def showMoney():Unit={
    println(s"现在的余额是:${balance}")
  }
  def deposit(money:Int):Unit={
    balance += money
  }
  def withdraw(money:Int):Unit={
    if(money <= balance)
      balance -= money
  }
  // 转账
  def transfer(to:BankAccount,money:Int):Unit={
    // A  --200--> B
    // A  减少 B 增加
  }
}

object Test22_1 {
  def main(args: Array[String]): Unit = {
    var xiaoming=new BankAccount(0)
    var xiaohua = new BankAccount(100)
    //存入 200
    xiaohua.deposit(200)
    //取出 150
    xiaohua.withdraw(1500)

    //转账给小明
    xiaohua.transfer(xiaohua,100)

    xiaohua.showMoney()
    xiaoming.showMoney()
  }
}

​
复制代码
private[this]方法
Scala 复制代码
package Test22
// 银行账户
class BankAccount(private[this] var balance:Int){
  def showMoney():Unit={
    println(s"现在的余额是:${balance}")
  }
  def deposit(money:Int):Unit={
    balance += money
  }
  def withdraw(money:Int):Unit={
    if(money <= balance)
      balance -= money
  }
  // 转账:把当前的账户的余额转出money给to这个账户
  def transfer(to:BankAccount,money:Int):Unit={
    // A  --200--> B
    // A  减少 B 增加
    if(money <= balance){
      //把自己减少
      balance -= money
      //把对方增加
//      to.balance += money
      to.deposit(money)
    }
  }
//  def test(to:BankAccount):Unit={
//    to.balance=0
//  }
}

object Test22_1 {
  def main(args: Array[String]): Unit = {
    var xiaoming=new BankAccount(0)
    var xiaohua = new BankAccount(100)
    //存入 200
    xiaohua.deposit(200)
    //取出 150
    xiaohua.withdraw(1500)

    //转账给小明
    xiaohua.transfer(xiaohua,100)

    xiaohua.showMoney()
    xiaoming.showMoney()
//    println(xiaohua.balance)
  }
}

Scala 的控制方法作用域有5种:

(1)默认访问权限

(2)protected 访问权限

(3)private 访问权限

(4)private[this]访问权限

(5)private[package]访问权限

Scala 复制代码
package Test22{

  class C() {
    private[p2] def test(): Unit = {
      println("test")
    }
  }

  object Test22_3 {
    def main(args: Array[String]): Unit = {
      var c1=new C()
      c1.test()
    }
  }
}
相关推荐
渣渣盟1 天前
基于Scala实现Flink的三种基本时间窗口操作
开发语言·flink·scala
zhojiew1 天前
关于akka官方quickstart示例程序(scala)的记录
后端·scala
小伍_Five4 天前
Spark实战能力测评模拟题精析【模拟考】
java·大数据·spark·scala·intellij-idea
黄雪超4 天前
DataStreamAPI实践原理——快速上手(实操详细版)
大数据·flink·scala
白总Server6 天前
C++语法架构解说
java·网络·c++·网络协议·架构·golang·scala
vortex56 天前
Perl One-liner 数据处理——基础语法篇【匠心】
开发语言·scala·perl
老兵发新帖8 天前
Coursier:安装sbt
scala
请你喝好果汁64111 天前
indel_snp_ssr_primer
大数据·开发语言·scala
MZWeiei14 天前
Spark 中,map和foreach的区别
大数据·分布式·spark·scala
MZWeiei15 天前
区分:union(),coalesce () 和 repartition ()
大数据·分布式·spark·scala