2012-06-16 17 views
17

En la antigüedad, cuando Invocation, una utilidad experimental, era una parte de la biblioteca estándar, se podría invocar métodos "dinámica" como se muestra a continuación:invocación de método "dinámico" con el nuevo Scala API reflexión

"Hello!" o 'substring(0, 4) // to get Any back 
"Hello!" oo 'substring(0, 4) // for an automatic unsafe cast to expected type 

Cómo hacer esto con la nueva API de reflexión de Scala?

+0

¿Por qué quiere llamar a métodos en tiempo de ejecución cuando ya conoce sus nombres/identificadores/parámetros? ¿Hay algo que no puedas lograr en el momento de la compilación? – sschaef

+0

@Antoras, solo curioso. No realmente usando estas cosas en producción. – missingfaktor

Respuesta

22
Welcome to Scala version 2.10.0-20120617-072418-9a28ee1ffc (Java HotSpot(TM) 64-Bit Server VM, Java 1.6.0_33). 
Type in expressions to have them evaluated. 
Type :help for more information. 

scala> class Foo { def bar(x: Int) = x } 
defined class Foo 

scala> val foo = new Foo 
foo @ 5935b50c: Foo = [email protected] 

scala> runtimeMirror(getClass.getClassLoader).reflect(foo) 
res0 @ 65c24701: reflect.runtime.universe.InstanceMirror = [email protected]65c24701 

scala> res0.symbol.typeSignature.member(newTermName("bar")) 
res1 @ 69624a1c: reflect.runtime.universe.Symbol = method bar 

scala> res0.reflectMethod(res1.asMethodSymbol)(42) 
res2 @ 4ac1d188: Any = 42 

Se puede encontrar información básica sobre cómo se diseña la API aquí: Get companion object instance with new Scala reflection API.

Cuestiones relacionadas