📄 tcpoly_typealias_eta.scala
字号:
trait A { type m[+x]}trait A2 { type m[+x <: String]}trait A3 { type m[x]}trait FooCov[+x]trait FooCon[-x]trait FooBound[+x <: String] trait BOk1 extends A { type m/*[+x]*/ = FooCov/*[x]*/}trait BOk2 extends A2 { type m/*[+x <: String]*/ = FooBound/*[x]*/}trait BOk3 extends A2 { type m/*[+x]*/ = FooCov/*[x]*/ // weaker bound}trait BOk4 extends A3 { type m/*[+x]*/ = FooCov/*[x]*/ // weaker variance}// there are two aspects to check: // does type alias signature (not considering RHS) correspond to abstract type member in super class // does RHS correspond to the type alias sigtrait BInv extends A{ type m/*[x]*/ = FooCov/*[x]*/ // error: invariant x in alias def}trait BCon extends A{ type m/*[-x]*/ = FooCon/*[x]*/ // error: contravariant x}trait BBound extends A{ type m/*[+x <: String]*/ = FooBound/*[x]*/ // error: x with stricter bound}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -