Nie bardzo możliwe, jak to ująłeś, ale można to zrobić przy użyciu wzorca klasy typu. Na przykład, od here:
sealed abstract class Acceptable[T]
object Acceptable {
implicit object IntOk extends Acceptable[Int]
implicit object LongOk extends Acceptable[Long]
}
def f[T: Acceptable](t: T) = t
scala> f(1)
res0: Int = 1
scala> f(1L)
res1: Long = 1
scala> f(1.0)
<console>:8: error: could not find implicit value for parameter ev: Acceptable[Double]
f(1.0)
^
EDIT
To działa, jeśli klasa i obiekt są towarzyszami. W REPL, jeśli wpiszesz każdą z nich w innym wierszu (tzn. Pojawi się między nimi "wynik"), nie są one towarzyszami. Można wpisać go jak poniżej, choć:
scala> sealed abstract class Acceptable[T]; object Acceptable {
| implicit object IntOk extends Acceptable[Int]
| implicit object LongOk extends Acceptable[Long]
| }
defined class Acceptable
defined module Acceptable
Dzięki, również odwołać http://ropas.snu.ac.kr/~bruno/papers/TypeClasses.pdf – oluies
@Brent Tak jak powiedziałem przez e-mail, jest to prawdopodobnie wynikiem wpisania klasy obiektu na różnych liniach. Zobacz moją edycję. –