4.scala默认参数值

Scala具备给参数提供默认值的能力,这样调用者就可以忽略这些具有默认值的参数。

scala 复制代码
def log(message: String, level: String = "INFO") = println(s"$level: $message")

log("System starting")  // prints INFO: System starting
log("User not found", "WARNING")  // prints WARNING: User not found

上面的参数level有默认值,所以是可选的。最后一行中传入的参数"WARNING"重写了默认值"INFO"。在Java中,我们可以通过带有可选参数的重载方法达到同样的效果。不过,只要调用方忽略了一个参数,其他参数就必须要带名传入。

scala 复制代码
class Point(val x: Double = 0, val y: Double = 0)

val point1 = new Point(y = 1)

这里必须带名传入y = 1

注意从Java代码中调用时,Scala中的默认参数则是必填的(非可选),如:

scala 复制代码
// Point.scala
class Point(val x: Double = 0, val y: Double = 0)
// Main.java
public class Main {
    public static void main(String[] args) {
        Point point = new Point(1);  // does not compile
    }
}
相关推荐
格砸43 分钟前
从入门到辞职|从ChatGPT到OpenClaw,跟上智能时代的进化
前端·人工智能·后端
蝎子莱莱爱打怪1 小时前
GitLab CI/CD + Docker Registry + K8s 部署完整实战指南
后端·docker·kubernetes
哈密瓜的眉毛美2 小时前
零基础学Java|第三篇:DOS 命令、转义字符、注释与代码规范
后端
用户60572374873082 小时前
AI 编码助手的规范驱动开发 - OpenSpec 初探
前端·后端·程序员
哈密瓜的眉毛美2 小时前
零基础学Java|第二篇:Java 核心机制与第一个程序:从 JVM 到 Hello World
后端
用户8307196840822 小时前
RabbitMQ vs RocketMQ 事务大对决:一个在“裸奔”,一个在“开挂”?
后端·rabbitmq·rocketmq
初次攀爬者2 小时前
RocketMQ 集群介绍
后端·消息队列·rocketmq
Leo8993 小时前
go 从零单排 之 一小时通关
后端
花花无缺3 小时前
搞懂@Autowired 与@Resuorce
java·spring boot·后端
CodeMonkey3 小时前
记一次傻逼一样的 OOM 异常
后端