从命令行执行 Java 比 IntelliJ 慢

Bje*_*rum 3 java command-line intellij-idea

我编写了一个简单的阶乘程序,具有任意精度:

public class Fac {
    public static void main(String[] args) {
        int stop = 100000;

        long start = System.currentTimeMillis();
        BigInteger integer = new BigInteger("1");
        for(int i = 2; i <= stop; i++){
            integer = integer.multiply(new BigInteger(i +""));
        }

        System.out.println("It took: " + (System.currentTimeMillis() - start) + "ms");
        //System.out.println(integer);
    }
}
Run Code Online (Sandbox Code Playgroud)

当我在 IntelliJ 中运行它时:

It took: 5392ms
Run Code Online (Sandbox Code Playgroud)

当我在命令行中运行它时:

It took: 17919ms
Run Code Online (Sandbox Code Playgroud)

命令行由以下人员运行:

javac Fac.java
java Fac
Run Code Online (Sandbox Code Playgroud)

我知道这不是衡量时间的最佳方式,但差距太大了,这无关紧要。为什么表现如此不同?

其他人也注意到了类似的差异,但是,据我所知,他们的结论似乎与我的情况无关。

与命令行相比,为什么我的应用程序在 IntelliJ 中运行得更快?

http://grails.1312388.n4.nabble.com/Why-does-IntelliJ-IDEA-runs-faster-than-Windows-command-line-td3894823.html

vik*_*eve 5

这是因为您正在启动 jvm 以使用不同的类路径、参数等运行您的程序。

如果您在 IntelliJ 中运行该程序,您将看到Run窗口的第一行类似于“C:\Program ...”

单击它以展开它,您将看到 intellij 运行您的程序时使用的所有参数(我在这里将示例分成几行)。

"C:\Program Files (x86)\Java\jdk1.8.0_40\bin\java"
-Didea.launcher.port=7532
 "-Didea.launcher.bin.path=C:\Program Files (x86)\JetBrains\IntelliJ IDEA 14.0.3\bin"
-Dfile.encoding=UTF-8
-classpath "C:\Program Files (x86)\Java\jdk1.8.0_40\jre\lib\charsets.jar;...etc..."
Fac
Run Code Online (Sandbox Code Playgroud)

如果您复制完全相同的参数(使用完全相同的 jvm),那么您在手动运行应用程序时可能会看到类似的性能。

如果您没有完全指定它们,默认情况下会使用PATH,JAVA_HOME和 的系统设置来CLASSPATH启动您的程序。