12函数参数

一. 函数参数的默认值

  1. 定义有默认值的函数

格式:

def 函数名(参数1:类型1=默认值1,参数2:类型2=默认值2)

  1. 定义一个函数,并使用不同的参数来测试使用。
Scala 复制代码
def hello(name: String = "小明", age: Int = 17, gender: String = "女"): Unit = {
  println(s"hello,我是${name},${age}岁,性别:${gender}")
}

def main(args: Array[String]): Unit = {
  hello("小花", 25, "女")
  hello("小明", 29, "男")
  hello("小招", 19) // 1. 不写性别,默认为女
  hello() // 2. 不写所有参数,全部使用默认值

  hello(age = 18) // 3.设置年龄为18,其他的参数使用默认值
  hello(gender = "男", name = "小李") // 4. 设置名字为小李,性别为男,年龄使用默认值
}

结果如下:

二. 创建不带()的方法

如果函数没有参数,可以省略定义函数时的( )

格式: def 方法名:[返回类型]={}。

scala 复制代码
def test: Unit = {
  println("test.......")
}


def main(args: Array[String]): Unit = {

  test  // 不用加()
}

结果如图:

三. 创建接受变参的方法

在Scala中创建接受变参的方法为:参数类型*,这种方式只能接受同一类型的参数。

问: 如何定义一个函数,它能接收数量不定的参数,并计算它们的累加?例如:getSum(1) 得到1, getSum(4,1,2,3,5) 得到15?

scala 复制代码
// 允许参数的个数不同,类型相同
// 变参:参数类型后边,加一个*
def getSum(args: Int*): Int = {
  var sum = 0
  for (i <- args) {
    sum += i
  }
  sum
}

def main(args: Array[String]): Unit = {
  val result1 = getSum(1)
  val result2 = getSum(4, 1, 2, 3, 5)
  println(result1, result2)
}

结果如图:

四. 案例

  1. 定义一个函数,判断给定的三个数字是否能构成一个三角形

  2. 判断一个数是不是素数

scala 复制代码
//  定义一个函数,判断给定的三个数字是否能构成一个三角形?
def testTriangle(a: Double, b: Double, c: Double): Boolean = {
  a + b > c && a + c > b && b + c > a
}

// 判断一个数是不是素数
def isPrimeNum(num: Int): Boolean = {
  var isPrimeNum = true
  for (i <- 2 to num - 1) {
    if (num % i == 0) {
      isPrimeNum = false
    }
  }
  isPrimeNum
}

def main(args: Array[String]): Unit = {
  val r = testTriangle(1.0, 2.0, 2.0)
  println(r)

  val r1 = isPrimeNum(9)
  println(r1)
}

结果如图:

相关推荐
是阿威啊7 天前
【用户行为归因分析项目】- 【企业级项目开发第五站】数据采集并加载到hive表
大数据·数据仓库·hive·hadoop·spark·scala
是阿威啊10 天前
【用户行为归因分析项目】- 【企业级项目开发第四站】模拟三类用户行为数据上传到Hadoop
大数据·hadoop·分布式·sql·scala
今天没有盐12 天前
Python字符串操作全解析:从基础定义到高级格式化
后端·scala·编程语言
是阿威啊13 天前
【用户行为归因分析项目】- 【企业级项目开发第一站】项目架构和需求设计
大数据·hive·hadoop·架构·spark·scala
代码于老总14 天前
【Scala 技巧】用隐式类给 String “开挂”:一行代码实现手机号 / 身份证号校验
scala
scala舔狗汪15 天前
scala的隐式对象和隐式类
scala
是阿威啊16 天前
【maap-analysis】spark离线数仓项目完整的开发流程
大数据·分布式·spark·scala
豚踢兔x20 天前
正则表达式应用-手机号打码
scala
代码于老总22 天前
正则表达式在 Scala 中的应用
scala
凯新生物1 个月前
聚乙二醇二生物素,Biotin-PEG-Biotin在生物检测中的应用
scala·bash·laravel·perl