Scala:如何在类和伴随对象之间进行继承
我试图在Scala中设置一个案例类层次结构,它使用伴随对象。每个case类都有一个具有隐式方法的伴生对象,但是,我想创建一个case类可以扩展的抽象类。问题是我没有办法使抽象类的伴生对象也抽象。以下是代码,我目前拥有:Scala:如何在类和伴随对象之间进行继承,scala,Scala,我试图在Scala中设置一个案例类层次结构,它使用伴随对象。每个case类都有一个具有隐式方法的伴生对象,但是,我想创建一个case类可以扩展的抽象类。问题是我没有办法使抽象类的伴生对象也抽象。以下是代码,我目前拥有: abstract class Call {} abstract class ArgumentsCall extends Call {} trait Jsonable[T] { implicit def convert: CodecJson[T] } case
abstract class Call {}
abstract class ArgumentsCall extends Call {}
trait Jsonable[T] {
implicit def convert: CodecJson[T]
}
case class VersionCall(version:String) extends Call //{"version": "0.1"}
object VersionCall {
implicit def convert: CodecJson[VersionCall] = casecodec1(VersionCall.apply, VersionCall.unapply)("version")
}
case class CommandCall(command:String,arguments:ArgumentsCall) extends Call //{"command": "pcap-file", "arguments": {"output-dir": "/opt/suricata_out/1", "filename": "/opt/suricata_fifo/1"}}
object CommandCall {
implicit def convert: CodecJson[CommandCall] = casecodec2(CommandCall.apply, CommandCall.unapply)("command","arguments")
}
case class PcapCall(outputDir:String,filename:String) extends ArgumentsCall
object PcapCall extends ArgumentsCall {
implicit def convert: CodecJson[PcapCall] = casecodec2(PcapCall.apply, PcapCall.unapply)("output-dir","filename")
}
case class Response(returnS:String, message:Option[String])
object Response {
implicit def convert: CodecJson[Response] = casecodec2(Response.apply, Response.unapply)("return","message")
}
编译器无法确定ArgumentsCall或其子级是否具有“隐式def convert:CodecJson”。
以下是实际的编译器错误:
[error] /blah/src/main/scala/helpers/JsonApi.scala:24: could not find implicit value for evidence parameter of type argonaut.EncodeJson[helpers.ArgumentsCall]
[error] implicit def convert: CodecJson[CommandCall] = casecodec2(CommandCall.apply, CommandCall.unapply)("command","arguments")
[error] ^
[error] one error found
[error] (compile:compile) Compilation failed
有人能给我一个很好的方法来解释类/伴生对象以及如何使用它们进行继承吗?我有一种感觉,我对如何实现这一点有一个根本性的误解
感谢继承层次结构和伴随对象是两个完全不同的问题。该类及其伴随对象只共享一个名称空间。事实上,伴侣对象可以从完全无关的事物中分离出来,它可以混合特征等
trait Helper {
def multiply(n:Int) = n*2
}
object AA extends Helper {
private def fun(i:Int) = multiply(i)
}
class AA {
def doubleFun(jj:Int) = AA.fun(jj)
}
请注意以下几点
- 成员函数
可以使用同伴对象的私有函数doubleFun
- 方法
可以使用helper trait中混合的乘法fun
- 但这并不意味着类AA的实例(即
)将从帮助线程继承!事实上,事实并非如此。它可以继承或混合完全不相关的其他特征valA=newAA
trait Helper {
def multiply(n:Int) = n*2
}
object AA extends Helper {
private def fun(i:Int) = multiply(i)
}
class AA {
def doubleFun(jj:Int) = AA.fun(jj)
}
请注意以下几点
- 成员函数
可以使用同伴对象的私有函数doubleFun
- 方法
可以使用helper trait中混合的乘法fun
- 但这并不意味着类AA的实例(即
)将从帮助线程继承!事实上,事实并非如此。它可以继承或混合完全不相关的其他特征valA=newAA