最近,有一位网友询问关于Java命令行参数方面的问题,因为在Java中参数有很多种,有不少的读者一直没弄明白,所以特意写下此篇文章。
此篇文章分2大块,第一块是不同参数的解释,第2块就是JVM源码论证~
图1-1给出了运行Java代码的命令行,其中包括了启动命令和不同种类的参数,分别用红、黄、黑、绿、蓝、粉 6种颜色代表。
命令
这个相信是一位Java程序员就能明白,使用javac命令编译Java代码,使用java命令运行class文件
命令参数
命令参数,从字面意思也能够理解,就是java命令携带的参数,读者可以使用java命令查看.
而这里特意使用 -D 参数,因为 -D 参数后面的内容会被解析成系统属性,也就是System.getProperty 方法可以拿到的属性。关于System.getProperty底层这里不做描述,因为一看便知。
JVM启动时参数
-Xms、-Xmx、-Xss、-Xint这系列参数笔者称为 "JVM启动时参数" ,为什么这么说呢?因为在JVM启动时会去解析-Xms、-Xmx、-Xss、-Xint这系列参数,解析出来的值会赋值到 "JVM内部运行时参数" 实际上JVM内部控制大小使用的是 "JVM内部运行时参数" ,所以-Xms、-Xmx、-Xss、-Xint 这系列参数仅仅是一层抽象,因为缩写、很短、很容易记忆,反而 "JVM内部运行时参数" 很长不好记忆。
JVM内部运行时参数
"JVM内部运行时参数"上面已经提及到,可能此刻很多读者区分不明白 " JVM启动时参数 " 和 "JVM内部运行时参数" 在src/share/vm/runtime/arguments.cpp 文件 parse_each_vm_init_arg中解析-Xmx参数是这样实现的。
// 解析 -Xmx
else if (match_option(option, "-Xmx", &tail) || match_option(option, "-XX:MaxHeapSize=", &tail)) {
julong long_max_heap_size = 0;
// 把-Xmx后面紧跟的数值赋值到long_max_heap_size
ArgsRange errcode = parse_memory_size(tail, &long_max_heap_size, 1);
…………
把long_max_heap_size赋值到全局的MaxHeapSize参数中
FLAG_SET_CMDLINE(uintx, MaxHeapSize, (uintx)long_max_heap_size);
}
可以很清楚的看到,把-Xmx的值赋值到MaxHeapSize中,而这里的-Xmx是" JVM启动时参数 ",MaxHeapSize是"JVM内部运行时参数"
而"JVM内部运行时参数"可以使用 -XX: 的形式设置。
所以 -XX:MaxHeapSize=1024m 和 -Xmx1024m没任何区别,而后续使用MaxHeapSize来设置堆大小。
启动类
设置启动类这个无需多提,但是有一点一定要注意,图1-1的案例来看,如果添加了很多参数的情况下,启动类的位置一定要在 "main方法参数"之前 (命令参数、JVM启动参数、JVM内部运行时参数要在启动类之前),也即启动类后面的参数都是 "main方法参数"。
main方法参数
这里很容易理解,你的启动类中存在main方法,而main方法传入一个String[]数组,这个字符串数组中就是参数。 上文有提及到,启动类后面的参数都是 "main方法参数"
案例论证
下面是 图1-1 的启动类代码,可以很清楚的看到,-D传入的参数使用System.getProperty方法拿到,main方法传入的数组的内容是csdn、hotspot 。这也完美论证了~!
public class Demo {
public static void main(String[] args) {
for (int i = 0; i < args.length; i++) {
System.out.println(args[i]);
}
System.out.println("liha参数内容:"+System.getProperty("liha"));
}
}
输出结果:
csdn
hotspot
liha参数内容:lihaha