Java中的日志记录-任何在变量每次更改时自动转储其值的方法



我正在寻找一种方法,在变量值更改时转储变量值,例如,到stdout,而无需手动编写日志或println代码,这样我就可以动态检查发生了什么。如果可能的话,还应该包括类名和源文件行号。

例如,使用以下内容:

public class SomeClass {
public static void main(java.lang.String[] args) {
someVariableA = 0;
someVariableB = 5;
someVariableC = 8;
someVariableD = someVariableA + someVariableB;
someVariableD = 9;

}
}

应该有一些输出,比如:

someVariableD = 5 at SomeClass.main(SomeClass.java:[lineNumber])
someVariableD = 9 at SomeClass.main(SomeClass.java:[lineNumber])

我应该能够在不写太多代码的情况下做到这一点,并且在不删除太多代码时禁用它。它应该能够显示每个变量的每一个变化。

对于像log4j这样的日志框架,我仍然需要编写代码来转储变量?

这是我可以用库/框架、Java编译器或JVM中的设置,还是用一些IDE来做的事情?

这就是为什么类不应该依赖于公开状态,也就是字段。

因为当某个"其他"对象更改这样的公共变量时,没有通知所有者的机制。

如果你想得到关于这些事情的通知,你可以将状态设为私有,但提供更新它的方法。然后你可以在上面使用observer模式,这样任何感兴趣的对象都会得到关于"属性更改"的通知。

出于调试目的,您当然可以设置对变量的监视。它将使用某种工具,以便对变量的赋值实际上变成方法调用。

您可以使用AspectJ截取字段分配;通过这种方式,您可以避免日志代码扰乱您的逻辑。

SomeClass.java

public class SomeClass {
private static int someVariableA;
private static int someVariableB;
private static int someVariableC;
private static int someVariableD;
public static void main(String[] args) {
someVariableA = 0;
someVariableB = 5;
someVariableC = 8;
someVariableD = someVariableA + someVariableB;
someVariableD = 9;
}
}

SomeAspect.java

import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.After;
import org.aspectj.lang.annotation.Aspect;
@Aspect
public class SomeAspect {
@After("set(static * SomeClass.*) && args(newValue)")
public void afterFieldSet(JoinPoint joinPoint, Object newValue) {
System.out.println(joinPoint.getSignature().getName() + " = " + newValue + " at " + joinPoint.getSourceLocation());
}
}

控制台输出将为:

someVariableA = 0 at SomeClass.java:9
someVariableB = 5 at SomeClass.java:10
someVariableC = 8 at SomeClass.java:11
someVariableD = 5 at SomeClass.java:12
someVariableD = 9 at SomeClass.java:13

当您想要禁用日志记录时,只需删除方面即可。

为了完整起见,我还在这里发布了用于构建的pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.example</groupId>
<artifactId>aspectj-example</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<properties>
<maven.compiler.source>1.6</maven.compiler.source>
<maven.compiler.target>1.6</maven.compiler.target>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<build>
<finalName>${project.artifactId}</finalName>
<plugins>
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>aspectj-maven-plugin</artifactId>
<version>1.11</version>
<executions>
<execution>
<goals>
<goal>compile</goal>
</goals>
<configuration>
<complianceLevel>${maven.compiler.source}</complianceLevel>
<source>${maven.compiler.source}</source>
<target>${maven.compiler.target}</target>
</configuration>
</execution>
</executions>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<version>3.1.0</version>
<configuration>
<archive>
<manifest>
<addClasspath>true</addClasspath>
<classpathPrefix>lib/</classpathPrefix>
<mainClass>SomeClass</mainClass>
</manifest>
</archive>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-dependency-plugin</artifactId>
<version>3.1.1</version>
<executions>
<execution>
<id>copy-dependencies</id>
<phase>prepare-package</phase>
<goals>
<goal>copy-dependencies</goal>
</goals>
<configuration>
<includeScope>runtime</includeScope>
<outputDirectory>${project.build.directory}/lib</outputDirectory>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
<dependencies>
<dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjweaver</artifactId>
<version>1.8.13</version>
</dependency>
<dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjrt</artifactId>
<version>1.8.13</version>
</dependency>
</dependencies>
</project>

要运行此示例,只需启动mvn clean package,然后启动java -jar target/aspectj-example.jar

您可以在其网站上找到更多关于AspectJ的信息。我希望它能有所帮助。

相关内容

最新更新