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()
    }
  }
}
相关推荐
盛小夏10 小时前
用 Python 把汉诺塔玩成“魔法”:从递归到可视化,一篇就够!
scala
智海观潮4 天前
学好Spark必须要掌握的Scala技术点
大数据·spark·scala
盛小夏5 天前
用链式风格写代码,就像在搭积木
scala
盛小夏7 天前
元组(Tuple)详解:初学者必须掌握的数据结构
scala
赞鱼儿7 天前
Scala中函数的基本使用
scala
还是大剑师兰特9 天前
Scala面试题及详细答案100道(71-80)-- 与Java的交互
scala·大剑师·scala面试题
927410 天前
12函数参数
scala
geilip14 天前
知识体系_scala_利用scala和spark构建数据应用
开发语言·spark·scala
Hello.Reader14 天前
Flink 高级配置发行版剖析、Scala 版本、Table 依赖与 Hadoop 集成实战
hadoop·flink·scala
IvanCodes18 天前
八、Scala 集合与函数式编程
大数据·开发语言·scala