我有以下 scala 类和带注释的 aspectj 类:
package playasjectj
import org.aspectj.lang.annotation.Pointcut
import org.aspectj.lang.annotation.Aspect
import org.aspectj.lang.annotation.Before
class Entity {
def foo(p:String):String ={
return p
}
def bar(handler:(String,String,Long)=>String):Unit={
handler("first", "second", 100L)
}
}
object Entity {
def main(args:Array[String]){
val inst = new Entity
inst.foo("we are the champion")
val handler = (first:String, second:String, value:Long) => {
first + second + ":" + value
}
inst.bar(handler)
}
}
@Aspect
class EntityAspect{
@Pointcut("execution(* foo(String) ) && target(playasjectj.Entity) && args(p)")
def pointcut_foo(p:String):Unit={}
@Pointcut("execution(* bar(scala.Function3<String,String,Long,String>)) && target(playasjectj.Entity) && args(handler)")
def pointcut_bar(handler: (String,String,Long)=>String):Unit={}
@Before("pointcut_foo(p)")
def beforeAdvice_foo(p:String):Unit={
println("before advice foo: " + p)
}
@Before("pointcut_bar(handler)")
def beforeAdvice_bar(handler:(String,String,Long)=>String):Unit={
println("before advice bar:")
}
}
功能 bar 运作良好,但功能 foo 没有。没有任何错误,似乎函数“foo”的执行没有被捕获。
[AppClassLoader@14dad5dc] 信息 AspectJ Weaver 版本 1.8.5 构建于 2015 年 1 月 29 日星期四 01:03:58 GMT
[AppClassLoader@14dad5dc] 信息注册类加载器 sun.misc.Launcher$AppClassLoader@14dad5dc
[AppClassLoader@14dad5dc] 使用配置的信息 /Users/grant/programming/java/workspace/playasjectj/bin/META-INF/aop.xml
[AppClassLoader@14dad5dc] info register aspect playasjectj.EntityAspect before advice foo:我们是冠军
任何人都知道如何解决这个问题?我想这与scala如何将元组转换为java类有关