我的主类引用了一个Settings.java
类,并且运行maven没有引用新属性,它可以正常工作:
mvn assembly:assembly
如果我引用了一个新属性,我会收到此错误:
[ERROR] /Users/.../service.java:[41,58] cannot find symbol
[ERROR] symbol : method getDefaultScore()
这是一个多项目的项目。依赖是一个本地的依赖,它只是另一个maven模块,因此不确定为什么它不会选择这个新属性。
我确实在root上运行mvn clean
,以防万一缓存。
注意:当我通过IntelliJ构建并运行它时,此应用程序正常工作,但是使用maven似乎并不喜欢这个新属性(它不仅仅是一个返回我赋值的字符串属性,它不是从属性文件或任何东西读取。)
使用debug运行时:
mvn assembly:assembly -X
我得到相同的'找不到符号',位置是我的另一个maven模块的类,然后我得到:
org.apache.maven.lifecycle.LifecycleExecutionException: Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:2.3.2:compile (default-compile) on project myapp-jobs: Compilation failure
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:213)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:153)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:145)
at org.apache.maven.lifecycle.internal.MojoExecutor.executeForkedExecutions(MojoExecutor.java:365)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:199)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:153)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:145)
at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:84)
at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:59)
at org.apache.maven.lifecycle.internal.LifecycleStarter.singleThreadedBuild(LifecycleStarter.java:183)
at org.apache.maven.lifecycle.internal.LifecycleStarter.execute(LifecycleStarter.java:161)
at org.apache.maven.DefaultMaven.doExecute(DefaultMaven.java:319)
at org.apache.maven.DefaultMaven.execute(DefaultMaven.java:156)
at org.apache.maven.cli.MavenCli.execute(MavenCli.java:537)
at org.apache.maven.cli.MavenCli.doMain(MavenCli.java:196)
at org.apache.maven.cli.MavenCli.main(MavenCli.java:141)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at org.codehaus.plexus.classworlds.launcher.Launcher.launchEnhanced(Launcher.java:290)
at org.codehaus.plexus.classworlds.launcher.Launcher.launch(Launcher.java:230)
at org.codehaus.plexus.classworlds.launcher.Launcher.mainWithExitCode(Launcher.java:409)
at org.codehaus.plexus.classworlds.launcher.Launcher.main(Launcher.java:352)
Caused by: org.apache.maven.plugin.CompilationFailureException: Compilation failure
at org.apache.maven.plugin.AbstractCompilerMojo.execute(AbstractCompilerMojo.java:656)
at org.apache.maven.plugin.CompilerMojo.execute(CompilerMojo.java:128)
at org.apache.maven.plugin.DefaultBuildPluginManager.executeMojo(DefaultBuildPluginManager.java:101)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:209)
... 23 more
为了确保,我用较旧的属性替换了新属性的引用,并且mvn命令运行正常,因此它是def。对新房产有疑问,简单地说:
public class Settings {
..
..
private String defaultScore = "100";
public String getDefaultScore() {
return defaultScore;
}
}
我的电脑/ maven版本等:
答案 0 :(得分:2)
请确保使用添加新属性的依赖项目的正确版本。如果此项目的版本为 1.0.0-SNAPSHOT (它是快照版本,对吗?),请确保在要查看该属性的项目中引用此版本。
验证完版本后,在根目录中运行mvn clean install
以重建所有依赖项。
如果这不起作用,请检查您当地的Maven存储库(在~/.m2
中)以检查该依赖项的JAR文件是否包含该类的最新版本。
答案 1 :(得分:0)
您是否尝试在第一个模块中运行mvn install
?