类型不接受Scala参数
我有case类State,希望从中扩展变量类;但在变量类中只需要构造函数中的值。我可以将类型不接受Scala参数,scala,constructor,Scala,Constructor,我有case类State,希望从中扩展变量类;但在变量类中只需要构造函数中的值。我可以将运行功能放在哪里 case class State[S, +A](run: S => (A, S)) { //.....has `map` function def map[B, X >: State[S, B]](f: A => B): X = State(state => { val (a, s2) = run(state) (f(a), s2)
运行
功能放在哪里
case class State[S, +A](run: S => (A, S)) {
//.....has `map` function
def map[B, X >: State[S, B]](f: A => B): X =
State(state => {
val (a, s2) = run(state)
(f(a), s2)
})
}
class Variable[+A](value: A) extends State[A, A] { // ERROR
def get: Variable[A] =
map(x => x)
def set(newValue: A): Variable[A] =
map(_ => newValue)
}
更新
我改成这样:
class Variable[+A](value: A, run: A => (A, A)) extends State[A, A](run) {
def get: Variable[A] =
map(x => x) // ERROR HERE
def set(newValue: A): State[A, A] =
map(_ => newValue)
}
object Variable {
def create[A](value: A): Variable[A] = new Variable[A](value, x => (x, x))
}
但我有一个错误:
类型失配;发现:com.libs.State[A,A]required:com.libs.Variable[A]Variable.scala/scala/src/com/libs第4行scala问题问题是无法使用
map
定义变量
,因为map
定义了状态
,它只是变量
的超类型。您的程序如何知道如何仅使用map
设置子类的附加信息
但是,如果定义type变量[+A]=State[A,A]
,使其不是子类而是同一类的别名,则会出现一些差异错误,因为State
在其类型参数S
中是不变的,因此Variable
必须也是不变的