前面的示例T m 0是“操作符表示法”的一个示例。 Scala有三种运算符符号,前缀(称为一元),中缀和后缀。让我们来看看这三个例子在这里的行动:
class MyByte(val n : Int) {
require(n >= 0 && n <= 255)
def unary_! = new MyByte(n^0xff)
def +(m : MyByte) = new MyByte(n + m.n)
def bits = (math.log(n)/math.log(2) + 1).toInt
override def toString = "0" * (8 - bits) + n.toBinaryString
}
一个在这里它是在使用中:
scala> val a = new MyByte(5)
a: MyByte = 00000101
scala> val b = new MyByte(10)
b: MyByte = 00001010
scala> ! a // Prefix/Unary
res58: MyByte = 11111010
scala> a + b // Infix
res59: MyByte = 00001111
scala> b bits // Postfix
res60: Int = 4
虽然缀和后缀符号接受任何有效的Scala的标识符,虽然有限制后缀符号的通话,只能使用四个标识符作为前缀:〜,!, - 和+。现在,当你尝试“m 0”时,Scala放弃它作为一元操作符,理由是它不是有效的(〜,!, - 和+)。它发现“m”是一个有效的对象 - 它是一个函数,而不是一个方法,所有的函数都是对象。
由于“0”不是有效的Scala标识符,它不能既不是中缀也不是后缀运算符。因此,斯卡拉抱怨说它预计“;” - 这将分隔两个(几乎)有效的表达式:“m”和“0”。如果你插入它,那么它会抱怨m需要一个参数,或者如果失败了,就用一个“_”把它变成一个部分应用的函数。
不要列出使用:::和::作为前缀符号吗? – andychase 2013-04-12 21:57:14