gpt4 book ai didi

scala - 如何在 case 类中使用另一个字段初始化一个字段?

转载 作者:行者123 更新时间:2023-12-04 10:03:50 26 4
gpt4 key购买 nike

假设我有一个案例类

case class Person(fname:String, lname:String, nickName:Option[String] = None)

创建类似Person(“John”,“Doe”)的实例时,如果没有给我昵称,我希望将nickName自动分配给fname。例如:
val p1 = Person("John", "Doe")
p1.nickName.get == "John"

val p2 = Person("Jane", "Doe", "Joe")
p2.nickName.get == "Joe"

如何实现一个领域与另一个领域的自动分配?

尝试以下repl中的解决方案。我认为这与REPL有关
scala> case class Person(fname: String, lname:String, nickName:Option[String])
defined class Person

scala> object Person { def apply(fname:String, lname:String):Person = {Person(fname, lname, Some(fname))}}
console:9: error: too many arguments for method apply: (fname: String, lname: String)Person in object Person
object Person { def apply(fname:String, lname:String):Person = {Person(fname, lname, Some(fname))}}

最佳答案

您可以重载case类的构造函数

case class Foo(bar: Int, baz: Int) {
def this(bar: Int) = this(bar, 0)
}
new Foo(1, 2)
new Foo(1)

因此,您可以检查nickName是否为none的情况。

您也可以以相同的方式重载它的apply方法。这样,您就可以使用
Foo(1,2)
Foo(1)

关于scala - 如何在 case 类中使用另一个字段初始化一个字段?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28179301/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com