你可以從這個SBT控制檯中看到輸出:
scala> :type implicit class Harden[S <% mutable.Set[_]](val set: S)
[S]AnyRef {
val set: S
private[this] val set: S
implicit private[this] val evidence$1: S => scala.collection.mutable.Set[_]
def <init>(set: S)(implicit evidence$1: S => scala.collection.mutable.Set[_]): Harden[S]
}
...幕後Harden
desugars實際的構造函數:
def <init>(set: S)(implicit evidence$1: S => scala.collection.mutable.Set[_]): Harden[S]
...(即取set
在一個參數列表中並且在另一箇中隱含evidence$1
)。
如圖值類限制here描述:
必須只有正好與一個公共的,VAL參數,其類型不是值類的主構造函數。
...... whitch意味着Harden
違反了此限制。
你可以實現類似的,高效的。嘗試將您在類上定義的視圖邊界轉換爲方法上的隱式證據。
事情是這樣的:
scala> implicit class Harden[S](val set: S) extends AnyVal {
| def cast[T](implicit ev: S => scala.collection.mutable.Set[_]) = set.map(_.asInstanceOf[T])
| }
defined class Harden
這將編譯:
scala> Set(1,2,3).cast[Any]
res17: scala.collection.mutable.Set[Any] = Set(1, 2, 3)
,這將失敗,因爲預期:
scala> List(1,2,3).cast[Any]
<console>:24: error: No implicit view available from List[Int] => scala.collection.mutable.Set[_].
List(1,2,3).cast[Any]
^
我認爲鑑於必然('<%')將從2.12棄用。就這樣你知道 – 2014-10-05 04:18:33