我很确定在Scala中这很简单,但我似乎无法弄清楚类型系统需要做什么提示才能使其工作.
我想要一个抽象的Printable类,然后隐式地将其他类转换为它.更具体地说,我想隐式地将Byte转换为Printable,将Array [Byte]转换为Printable.
所以我做到了这一点:
abstract class Printable{
def print():String
}
class PrintableByte(b:Byte) extends Printable{
def print() = "" /*return something*/
}
implicit def printableByte(b:Byte) = new PrintableByte(b)
class PrintableArray(a:Array[Printable]) extends Printable{
def print() = {
for(i <- 0 until a.length) a(i).print() // no problems here
"" /*return something*/
}
}
implicit def printableArray(a:Array[Printable]) = new PrintableArray(a)
Run Code Online (Sandbox Code Playgroud)
然而:
val b:Byte = 0
b.print() //no problem here
val a= new Array[Byte](1024)
a.print() //error: value print() is not a member of Array[Byte]
Run Code Online (Sandbox Code Playgroud)
我期望类型系统能够理解Array [Byte]隐式地是一个Array [Printable]并且隐式地是Printable.
我错过了什么?
只是我的两分钱:
abstract class Printable{
def print: String
}
class PrintableArray[T <% Printable](a: Array[T]) extends Printable{
def print = (for(x <- a) yield x.print) mkString
}
implicit def printableArray[T <% Printable](a: Array[T]) = new PrintableArray(a)
class PrintableByte(b: Byte) extends Printable{
def print = "%#02x" format b
}
implicit def printableByte(b:Byte) = new PrintableByte(b)
class PrintableInt(i: Int) extends Printable{
def print = "%#08x" format i
}
implicit def printableInt(i: Int) = new PrintableInt(i)
Run Code Online (Sandbox Code Playgroud)
然后:
scala> val b: Byte = -1
b: Byte = -1
scala> val i: Int = 100
i: Int = 100
scala> val bArr = Array[Byte](11,22,33,44)
bArr: Array[Byte] = Array(11, 22, 33, 44)
scala> val iArr = Array[Int](111111,222222,333333,444444)
iArr: Array[Int] = Array(111111, 222222, 333333, 444444)
scala> b print
res0: String = 0xff
scala> i print
res1: String = 0x000064
scala> bArr print
res2: String = 0xb0x160x210x2c
scala> iArr print
res3: String = 0x01b2070x03640e0x0516150x06c81c
scala>
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1296 次 |
| 最近记录: |