Java 如何让AspectJ负载编织在Gradle上工作(特别是libgdx构建)
所以我想在我的libgdx游戏中注入一些测试和日志功能 因此,我在主桌面gradle依赖项中添加了以下内容Java 如何让AspectJ负载编织在Gradle上工作(特别是libgdx构建),java,gradle,libgdx,aspectj,Java,Gradle,Libgdx,Aspectj,所以我想在我的libgdx游戏中注入一些测试和日志功能 因此,我在主桌面gradle依赖项中添加了以下内容 compile 'org.aspectj:aspectjweaver:1.8.2' compile "org.aspectj:aspectjrt:1.8.2" 起初它没有找到依赖项,但通过关闭脱机模式和关闭并重新打开IntelliJ项目(Gradle sync按钮不起作用)解决了这个问题 我的理解是aspectjweaver必须作为java代理加载。所以我找到了它出现的地
compile 'org.aspectj:aspectjweaver:1.8.2'
compile "org.aspectj:aspectjrt:1.8.2"
起初它没有找到依赖项,但通过关闭脱机模式和关闭并重新打开IntelliJ项目(Gradle sync按钮不起作用)解决了这个问题
我的理解是aspectjweaver必须作为java代理加载。所以我找到了它出现的地方,gradle下载了它,并在我的VM运行时配置选项中添加了以下内容
-javaagent:/Users/daniel/.gradle/caches/modules-2/files-2.1/org.aspectj/aspectjweaver/1.8.2/4963c0bef4748d5ad039cc26c1ac32a082eb755e/aspectjweaver-1.8.2.jar
令人惊讶的是,这给了我以下警告信息
objc[66447]: Class JavaLaunchHelper is implemented in both /Library/Java/JavaVirtualMachines/jdk1.8.0_05.jdk/Contents/Home/bin/java and /Library/Java/JavaVirtualMachines/jdk1.8.0_05.jdk/Contents/Home/jre/lib/libinstrument.dylib. One of the two will be used. Which one is undefined.
如果没有-javaagent行,则不存在该消息
我试着按照这个例子来做一个负载编织的例子。
但是,我不需要一个单独的可重用方面,因此我只是在src目录中创建了一个基本的aop.xml文件,其中包含以下内容
<aspectj>
<weaver options="-verbose"/>
</aspectj>
…但不太熟悉教程中提到的iajc,知道如何在libgdx构建脚本中使用它似乎也很复杂。我不会提供gradle实现,而是使用AspectJ提供Maven实现。显然,您必须定制/调整以满足您的需求。
下面是bar.foo
方法的一个方面,该方法采用两个参数(字符串,布尔值)
,带有@环绕
建议和处理连接点
。
显然,任何建议或切入点都可以实现
JAVA
@Aspect
@ajcPrivileged
public class MyAspect {
@Pointcut("execution(* bar.foo(String, Boolean)) && args(string, bool)")
void foo(String string, Boolean bool) {}
@Around(value = "loadFile(filePathName, toGray)", argNames = "filePathName, toGray")
public MyReturnType foo(final ProceedingJoinPoint joinPoint, final String string, final Boolean bool) throws MyEx {
//impl
}
}
POM
请参见Weave third party dependency comment以定义要编织的第三方库
<project ..>
..
<properties>
<aspectj-maven-plugin.version>1.7</aspectj-maven-plugin.version>
<aspectjrt.version>1.8.2</aspectjrt.version>
..
</properties>
<dependencies>
<dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjrt</artifactId>
<version>${aspectjrt.version}</version>
</dependency>
..
</dependencies>
<build>
..
<plugins>
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>aspectj-maven-plugin</artifactId>
<version>${aspectj-maven-plugin.version}</version>
<configuration>
<complianceLevel>${java.version}</complianceLevel>
<source>${java.version}</source>
<target>${java.version}</target>
<!-- Weave third party dependency -->
<weaveDependencies>
<weaveDependency>
<groupId>yourThirdPartyDepGroupId</groupId>
<artifactId>yourThirdPartyDepGroupIdArtifactId</artifactId>
</weaveDependency>
</weaveDependencies>
</configuration>
<!-- Weave on compile -->
<executions>
<execution>
<goals>
<goal>compile</goal>
<goal>test-compile</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
<pluginManagement>
<plugins>
<!--This plugin's configuration is used to store Eclipse m2e settings only. It has no influence on the Maven build itself.-->
<plugin>
<groupId>org.eclipse.m2e</groupId>
<artifactId>lifecycle-mapping</artifactId>
<version>${lifecycle-mapping.version}</version>
<configuration>
<lifecycleMappingMetadata>
<pluginExecutions>
<pluginExecution>
<pluginExecutionFilter>
<groupId>org.codehaus.mojo</groupId>
<artifactId>aspectj-maven-plugin</artifactId>
<versionRange>[1.7,)</versionRange>
<goals>
<goal>compile</goal>
</goals>
</pluginExecutionFilter>
<action>
<ignore></ignore>
</action>
</pluginExecution>
</pluginExecutions>
</lifecycleMappingMetadata>
</configuration>
</plugin>
</plugins>
</pluginManagement>
</build>
</project>
..
1.7
1.8.2
..
org.aspectj
aspectjrt
${aspectjrt.version}
..
..
org.codehaus.mojo
aspectj maven插件
${aspectj maven plugin.version}
${java.version}
${java.version}
${java.version}
您的第三方分组ID
您的第三方PGROUPIDARTIFACTID
编译
测试编译
org.eclipse.m2e
生命周期映射
${lifecycle mapping.version}
org.codehaus.mojo
aspectj maven插件
[1.7,)
编译
您能否在gradle中成功加载时间编织?