gpt4 book ai didi

java - Java 9 ea 有启动时间倒退吗?

转载 作者:搜寻专家 更新时间:2023-10-30 20:00:08 28 4
gpt4 key购买 nike

听说过

  1. JVM 在每个主要版本中变得更快(在某些方面)
  2. 9 的模块化将带来更快的启动时间。

为了加速 Maven 构建,我下载了 jdk9-ea 并发现它需要更长的时间。而且,感觉Maven启动前的延迟比较长。

我尝试使用以下代码粗略测量 JVM 启动时间

public class Sampler {
public static void main(String[] args) throws IOException, InterruptedException {
long t = System.currentTimeMillis();
if (args.length == 0 || args[0].startsWith("-")) {
sample(30, args);
} else {
long t0 = Long.parseLong(args[0]);
System.out.println(t - t0);
}
}

static void sample(int n, String[] options) throws IOException, InterruptedException {
File samples = new File("samples.txt");
for (int i = 0; i < n; i++) {
String javaPath = String.join(
System.getProperty("file.separator"),
System.getProperty("java.home"),
"bin",
"java");

List<String> command = new ArrayList<String>();
command.add(javaPath);
command.addAll(Arrays.asList(options));
command.add("Sampler");
command.add(Long.toString(System.currentTimeMillis()));

ProcessBuilder processBuilder = new ProcessBuilder(command)
.inheritIO()
.redirectOutput(ProcessBuilder.Redirect.appendTo(samples));

Process process = processBuilder.start();
process.waitFor();
}
prettyPrint(samples);
samples.delete();
}
...
}

而且从 Java 9 开始需要两倍的时间

>java -versionjava version "1.8.0_74"Java(TM) SE Runtime Environment (build 1.8.0_74-b02)Java HotSpot(TM) Client VM (build 25.74-b02, mixed mode, sharing)>javac Sampler.java && java Samplern=30 units=milisec min=124 max=205 mean=143 median=132>java -versionjava version "9-ea"Java(TM) SE Runtime Environment (build 9-ea+111)Java HotSpot(TM) Client VM (build 9-ea+111, mixed mode)>javac Sampler.java && java Samplern=30 units=milisec min=279 max=387 mean=301 median=294>javac Sampler.java && java Sampler -XX:+UseParallelGCn=30 units=milisec min=279 max=382 mean=297 median=292>java -versionjava version "1.8.0_76-ea"Java(TM) SE Runtime Environment (build 1.8.0_76-ea-b04)Java HotSpot(TM) Client VM (build 25.76-b04, mixed mode, sharing)>javac Sampler.java && java Samplern=30 units=milisec min=123 max=227 mean=159 median=141>java Sampler -XX:+UseG1GCn=99 units=milisec min=188 max=340 mean=213 median=199

注意:最初我使用的是服务器虚拟机 (x64),相同的 2 倍差距,Java9 启动时间约为 0.6 秒。


java -Xshare:dump 之后

>java -versionjava version "9-ea"Java(TM) SE Runtime Environment (build 9-ea+111)Java HotSpot(TM) Client VM (build 9-ea+111, mixed mode, sharing)>javac Sampler.java && java Samplern=50 units=milisec min=228 max=422 mean=269 median=269>javac Sampler.java && java Sampler -Xshare:on<error messages>n=44 units=milisec min=227 max=392 mean=247 median=238>javac Sampler.java && java Sampler -Xshare:offn=50 units=milisec min=280 max=513 mean=315 median=288>javac Sampler.java && java Sampler -Xshare:auton=50 units=milisec min=228 max=361 mean=283 median=285

使用 Java 8

>java -Xshare:off Samplern=99 units=milisec min=124 max=264 mean=150 median=136

错误信息:

An error has occurred while processing the shared archive file. Unable to map ReadOnly shared space at required address.Error occurred during initialization of VMUnable to use shared archive.

50 次中有 44 次成功开始是我能得到的最高数字。最低的是 - 13。

最佳答案

是的,在当前的 EA 构建中肯定存在一些启动倒退 - 一些原因是已知的并且正在积极解决 - 其他更像是“千刀万剐”的磨难:在开发过程中积累的小而微不足道的低效率JDK 9 作为功能实现和集成,然后必须在实际发布之前进行微调和优化。

编辑:在后续的 JDK 版本中,我们消除了 JDK 9 引入的大多数启动回归。一个值得注意的异常(exception)是由 JEP 280 引起的启动回归。 JDK 库中无害的字符串连接可能会在某些应用程序中导致很小但很明显的开销。

关于java - Java 9 ea 有启动时间倒退吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35180051/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com