Arn*_*rne 10 scripting interpreter scala runtime-compilation classloader
可能重复:
Scala中的"eval"
我知道scala是一种编译语言,但我也知道我可以动态地将类加载到jvm中,我可以在运行时调用scala编译器,最后但并非最不重要的是我也有一个很棒的repl,所以让scala作为一个脚本语言应该是可能的.
所以我需要运行一些任务:
简单解释:
val src = """ println("Hello World") """
interpret(src)
Run Code Online (Sandbox Code Playgroud)
调用外部函数:
object A{
def foo =
println("Hello World")
}
val src = """ A.foo """
interpret(src)
Run Code Online (Sandbox Code Playgroud)
实现功能:
trait T{
def foo:String
}
val src = """ class A extends T{ def foo = "Hello World" } """
interpret(src)
val t = loadClassAndCreatInstance.asInstanceOf[T]
println(t.foo)
Run Code Online (Sandbox Code Playgroud)
能够解决我所有的问题会很棒.
我已经以某种方式找到了如何使用scala作为脚本语言,但是classLoader仍然存在问题
object O{
def foo = println("Hello World in object O")
}
trait T{
def foo:String
}
object MyInterpreter extends App{
val srcA =
"""
println("Hello World from srcA")
"""
val srcB = """ O.foo """
val srcC = """
class A extends T{
def foo = "Hello World from srcC"
override def toString = "this is A in a src"
}
"""
val out = System.out
val flusher = new java.io.PrintWriter(out)
val interpreter = {
val settings = new import scala.tools.nsc.GenericRunnerSettings( println _ )
new scala.tools.nsc.interpreter.IMain(settings, flusher)
}
interpreter.interpret(srcA)
interpreter.interpret(srcB)
interpreter.compileString(srcC)
val classA = interpreter.classLoader.findClass("A")
println(classA)
val constructors = classA.getDeclaredConstructors
val myinstance = constructors(0).newInstance()
println(myinstance)
//this still throws an classCastException
myinstance.asInstanceOf[T].foo
//but everything else works
}
Run Code Online (Sandbox Code Playgroud)