首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在Java中记录-每次变量的值发生变化时自动转储它们的任何方式

在Java中记录-每次变量的值发生变化时自动转储它们的任何方式
EN

Stack Overflow用户
提问于 2018-07-15 02:38:38
回答 2查看 374关注 0票数 4

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

例如,具有以下内容:

代码语言:javascript
复制
public class SomeClass {

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


    }

}

应该会有一些输出,如:

代码语言:javascript
复制
someVariableD = 5 at SomeClass.main(SomeClass.java:[lineNumber])
someVariableD = 9 at SomeClass.main(SomeClass.java:[lineNumber])

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

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

这是不是可以通过库/框架、Java编译器或JVM中的设置或某个IDE来完成?

EN

回答 2

Stack Overflow用户

发布于 2018-07-15 02:45:19

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

因为当一些“其他”对象改变这样的公共变量时,没有机制通知所有者。

如果你想得到关于这类事情的通知,你可以将state设为私有的,但是提供一些方法来更新它。然后,您可以在此基础上使用观察者模式,以便任何感兴趣的对象都能收到有关“属性更改”的通知。

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

票数 1
EN

Stack Overflow用户

发布于 2018-07-15 05:16:17

您可以使用AspectJ来截取字段赋值;通过这种方式,您可以避免使用日志记录代码弄乱您的逻辑。

SomeClass.java

代码语言:javascript
复制
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

代码语言:javascript
复制
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());
    }
}

控制台输出将为:

代码语言:javascript
复制
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

代码语言:javascript
复制
<?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的website上找到更多关于它的信息。我希望它能帮上忙。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51342390

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档