㈠ maven工程怎样将jre版本改成1.8
诸如此类的快速解决方案,但是当我们选择快捷方式或者项目右键–>Properties–>Project Facets 右边java 版本选项此类回的解决方案解答决后当再次选择 maven -> Update Project 更新的时候,会出现jre又回到了原来的版本,所以为了避免这种情况就需要设置依赖的jre的版本。
㈡ jdk1.8下maven3.3.3报错版本不对.除了用jdk1.6,还有什么办法吗
maven 3.3 .3貌似还不支持jdk8,我也遇到了这问题,最后换了7好了官网貌似说支持7及以上的版本,但是确实不行。不过java多版本可以同时存在,你不想删除8可以重新再装个7或6,alias命令动态切换java版本就可以了。具体操作:1、打开终端 cd到根路径, cd -2、输入vi .bash_profile打开bash配置文件3、再配置文件bash配置文件下新增JAVA_HOME的路径export JAVA_6_HOME=/Library/Java/JavaVirtualMachines/1.6.0.jdk/Contents/Homeexport JAVA_7_HOME=/Library/Java/JavaVirtualMachines/jdk1.7.0_79.jdk/Contents/Homeexport JAVA_8_HOME=/Library/Java/JavaVirtualMachines/jdk1.8.0_60.jdk/Contents/Homeexport JAVA_HOME=$JAVA_7_HOME4、创建alias命令动态切换JAVA_HOME的配置alias jdk8='export JAVA_HOME=$JAVA_8_HOME'alias jdk7='export JAVA_HOME=$JAVA_7_HOME'alias jdk6='export JAVA_HOME=$JAVA_6_HOME'5、终端输入source .bash_profile 保存配置文件配置的默认是7,想切换8直接终端输入jdk8就切换成8了。
㈢ 怎么更改maven的java版本
maven更改编译环境的java版本<build><plugins><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-compiler-plugin</artifactId><configuration><source>1.7</source><target>1.7</target></configuration></plugin></plugins> </build>以上是pom.xmlsettings.xml中也可以更版改,如下权<profile><id>jdk17</id><activation><activeByDefault>true</activeByDefault><jdk>1.7</jdk></activation><properties><maven.compiler.source>1.7</maven.compiler.source><maven.compiler.target>1.7</maven.compiler.target><maven.compiler.compilerVersion>1.7</maven.compiler.compilerVersion></properties> </profile>
㈣ maven配置好之后,按照路径输入后结果不能显示maven的版本是什么原因
java升级版本到1.7,如果你有其他软件需要用到1.7以下的,可以同时安装,不过需要编辑mvn目录下bin\mvn.cmd修改%JAVA_HOME%为java1.7的路径即可
㈤ maven怎么设置默认jre版本
步骤如下:Eclipse中,窗口——首选项--JAVA--已安装的JRE——添加。JRE名称写的是哪个版版权本的,如1.6版本的,就写JDK1.6.JRE主目录,单击浏览选择JDK路经。记住,选择主目录就行了。这样添加后在JRE系统库中会有显示文件。最后单击确定,就OK了
㈥ 如何修改Maven的JDK版本
1、使用maven的时候,默认会使用1.5版本的JDK,并且也是编译成1.5的,我的电脑里面用的JDK是1.7的,1.8也出来了,没理由还用1.5的吧!所以我手动改成了1.7,郁闷的是,每次 maven-update project 的时候,又变成1.5的了2、查阅了相关资料后,发现了修改的方法,打开maven安装目录下的 maven–》conf 3、修改settings.xml,找到profiles节点,在里面添加<profile> <id>jdk-1.7</id> <activation> <activeByDefault>true</activeByDefault> <jdk>1.7</jdk> </activation> <properties> <maven.compiler.source>1.7</maven.compiler.source> <maven.compiler.target>1.7</maven.compiler.target> <maven.compiler.compilerVersion>1.7</maven.compiler.compilerVersion> </properties> </profile> 4、最后,再次在eclipse中 maven–》update project 就会发现,maven的JDK版本变化了!
㈦ 如何用maven将java8写的代码编译为java6平台的
在一般的Java应用开发过程中,开发人员使用Java的方式比较简单。打开惯用的IDE,编写Java源代码,再利用IDE提供的功能直接运行Java 程序就可以了。这种开发模式背后的过程是:开发人员编写的是Java源代码文件(.java),IDE会负责调用Java的编译器把Java源代码编译成平台无关的字节代码(byte code),以类文件的形式保存在磁盘上(.class)。Java虚拟机(JVM)会负责把Java字节代码加载并执行。Java通过这种方式来实现其“编写一次,到处运行(Write once, run anywhere)” 的目标。Java类文件中包含的字节代码可以被不同平台上的JVM所使用。Java字节代码不仅可以以文件形式存在于磁盘上,也可以通过网络方式来下载,还可以只存在于内存中。JVM中的类加载器会负责从包含字节代码的字节数组(byte[])中定义出Java类。在某些情况下,可能会需要动态的生成 Java字节代码,或是对已有的Java字节代码进行修改。这个时候就需要用到本文中将要介绍的相关技术。首先介绍一下如何动态编译Java源文件。动态编译Java源文件在一般情况下,开发人员都是在程序运行之前就编写完成了全部的Java源代码并且成功编译。对有些应用来说,Java源代码的内容在运行时刻才能确定。这个时候就需要动态编译源代码来生成Java字节代码,再由JVM来加载执行。典型的场景是很多算法竞赛的在线评测系统(如PKU JudgeOnline),允许用户上传Java代码,由系统在后台编译、运行并进行判定。在动态编译Java源文件时,使用的做法是直接在程序中调用Java编译器。JSR 199引入了Java编译器API。如果使用JDK 6的话,可以通过此API来动态编译Java代码。比如下面的代码用来动态编译最简单的Hello World类。该Java类的代码是保存在一个字符串中的。01 public class CompilerTest {02 public static void main(String[] args) throws Exception {03 String source = "public class Main { public static void main(String[] args) {System.out.println(\"Hello World!\");} }";04 JavaCompiler compiler = ToolProvider.getSystemJavaCompiler();05 StandardJavaFileManager fileManager = compiler.getStandardFileManager(null, null, null);06 StringSourceJavaObject sourceObject = newCompilerTest.StringSourceJavaObject("Main", source);07 Iterable< extends JavaFileObject> fileObjects = Arrays.asList(sourceObject);08 CompilationTask task = compiler.getTask(null, fileManager, null,null, null, fileObjects);09 boolean result = task.call();10 if (result) {11 System.out.println("编译成功。");12 }13 }1415 static class StringSourceJavaObject extends SimpleJavaFileObject {1617 private String content = null;18 public StringSourceJavaObject(String name, String content) ??throwsURISyntaxException {19 super(URI.create("string:///" + name.replace('.','/') + Kind.SOURCE.extension), Kind.SOURCE);20 this.content = content;21 }2223 public CharSequence getCharContent(boolean ignoreEncodingErrors) ??throws IOException {24 return content;25 }26 }27 }如果不能使用JDK 6提供的Java编译器API的话,可以使用JDK中的工具类com.sun.tools.javac.Main,不过该工具类只能编译存放在磁盘上的文件,类似于直接使用javac命令。另外一个可用的工具是Eclipse JDT Core提供的编译器。这是Eclipse Java开发环境使用的增量式Java编译器,支持运行和调试有错误的代码。该编译器也可以单独使用。Play框架在内部使用了JDT的编译器来动态编译Java源代码。在开发模式下,Play框架会定期扫描项目中的Java源代码文件,一旦发现有修改,会自动编译 Java源代码。因此在修改代码之后,刷新页面就可以看到变化。使用这些动态编译的方式的时候,需要确保JDK中的tools.jar在应用的 CLASSPATH中。下面介绍一个例子,是关于如何在Java里面做四则运算,比如求出来(3+4)*7-10的值。一般的做法是分析输入的运算表达式,自己来模拟计算过程。考虑到括号的存在和运算符的优先级等问题,这样的计算过程会比较复杂,而且容易出错。另外一种做法是可以用JSR 223引入的脚本语言支持,直接把输入的表达式当做JavaScript或是JavaFX脚本来执行,得到结果。下面的代码使用的做法是动态生成Java源代码并编译,接着加载Java类来执行并获取结果。这种做法完全使用Java来实现。01 private static double calculate(String expr) throws CalculationException {02 String className = "CalculatorMain";03 String methodName = "calculate";04 String source = "public class " + className05 + " { public static double " + methodName + "() { return " + expr +"; } }";06 //省略动态编译Java源代码的相关代码,参见上一节07 boolean result = task.call();08 if (result) {09 ClassLoader loader = Calculator.class.getClassLoader();10 try {11 Class<?> clazz = loader.loadClass(className);12 Method method = clazz.getMethod(methodName, new Class<?>[] {});13 Object value = method.invoke(null, new Object[] {});14 return (Double) value;15 } catch (Exception e) {16 throw new CalculationException("内部错误。");17 }18 } else {19 throw new CalculationException("错误的表达式。");20 }21 }上面的代码给出了使用动态生成的Java字节代码的基本模式,即通过类加载器来加载字节代码,创建Java类的对象的实例,再通过Java反射API来调用对象中的方法。Java字节代码增强Java 字节代码增强指的是在Java字节代码生成之后,对其进行修改,增强其功能。这种做法相当于对应用程序的二进制文件进行修改。在很多Java框架中都可以见到这种实现方式。Java字节代码增强通常与Java源文件中的注解(annotation)一块使用。注解在Java源代码中声明了需要增强的行为及相关的元数据,由框架在运行时刻完成对字节代码的增强。Java字节代码增强应用的场景比较多,一般都集中在减少冗余代码和对开发人员屏蔽底层的实现细节上。用过JavaBeans的人可能对其中那些必须添加的getter/setter方法感到很繁琐,并且难以维护。而通过字节代码增强,开发人员只需要声明Bean中的属性即可,getter/setter方法可以通过修改字节代码来自动添加。用过JPA的人,在调试程序的时候,会发现实体类中被添加了一些额外的 域和方法。这些域和方法是在运行时刻由JPA的实现动态添加的。字节代码增强在面向方面编程(AOP)的一些实现中也有使用。
㈧ 为什么Maven Update Project JDK变回1.5
主要原因是每次Update时,它就会使用settings文件下的默认值。(原来这是maven自己捣的鬼)
Maven官方文档有如下描述:
编译器插件用来编译项目的源文件.从3.0版本开始,
用来编译Java源文件的默认编译器是javax.tools.JavaCompiler (如果你是用的是java 1.6) 。如果你想强制性的让插件使用javac,你必须配置插件选项 forceJavacCompilerUse。同时需要注意的是目前source选项和target 选项的默认设置都是1.5, 与运行Maven时的JDK版本无关。如果你想要改变这些默认设置, 可以参考 Setting the -source and -target of the Java Compiler中的描述来设置 source 和target 选项。
这是Maven已知的一个特性。除非在你的POM文件中显示的指定一个版本,否则会使用编译器默认的source/target版本1.5。主要还是在于Eclipse中Maven的集成方式起到了关键作用, 它会从POM文件中生成项目的.project,.classpath以及.settings, 因此除非POM文件指定了正确的JDK版本, 否则你每次更新项目配置的时候它都会重置到1.5版本。
解决方案
方案一
在pom.xml文件中增加如下配置:
修改Eclipse中的设置,使配置生效。此方案全局有效。
㈨ Maven项目如何快速的将pom中的资源更新到网上最新的稳定版本
置条件:1.安装有吃饭的家伙JAVA和MAVEN.首先,需要有一个packaging类型为pom的pom.xml文件即我们的parent项目pom文件.在这个parent项目中配置好groupId,artifactId,version以及properties,prerequisites,dependencies.还有一个重要的配置项是moles.加入了这个项目之后执行maven版本号更新时才会同时去更新子模块的版本号.子模块改变的部分:com.hlfcommon-parent0.0.1-SNAPSHOTcom.hlfprojectA发现没有,在这里只放了父模块的version没有放子模块的.这时我们执行:>mvnversions:set-DnewVersion=0.0.2-SNAPSHOT会发现在父模块和子模块下面都生成maven的版本控制文件(姑且这么叫吧,虽然看起来就是一个文件备份)pom.xml.versionsBackup.同时,父模块和子模块的verion都更新为了0.0.2-SNAPSHOT.com.hlfcommon-parent0.0.2-SNAPSHOTcom.hlfprojectA到这里已经完成了子模块的版本号更新.