java启动参数的问题 在jdk1.3中, java -D 代表系统参数设置,比如安全,好象没有你列出的,你说详细点? 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 我用的是jdk1.3.1,在Linux下,发现有许多参数可以用,我不知道加上这些参数对性能有什么影响。 第一、你的JDK是什么版本啊?我的好象不是这样……第二、用处说得很清楚了啊……你不会告诉我你不会E文吧?第三、一般情况下不怎么用这些参数…… to ender: 我听说java虚拟机能使用的内存量和性能与启动参数有关,上面的英文解释那么简略,你光看这个就能优化系统性能??? 从解释上来看有些参数挺有用,我想问问谁用过这些东西,到底有没有效果。 透过 Java 参数来改善 Java 效能 (艾群科技 萧松瀛)作者 : 艾群科技 萧松瀛 我们都知道, Java 在执行的时候会吃掉不少记忆体,而当记忆体不够用的时候, JVM 会向系统要求更大的记忆体来使用。但是实际上对於 Ja va 来说,我们会发现资料可以存在许多不同的地方,其中有两个重要的是 Heap 以及 Stack 。这两者有什么差别,我们在以後会提到,但是在这之前,我们先来看一个程式: public class testHeap { public static void main(String argv[]) { StringBuffer sb = new StringBuffer(); long starttime; long endtime; starttime = System.currentTimeMillis(); for(int i=0; i <=100000; i++) { sb.append(i).append("hello").append(i); if(i % (100000/2) == 0) { System.out.println(Runtime.getRuntime().totalMe mory()); } } endtime = System.currentTimeMillis(); System.out.println("Time: "+(endtime-starttim e)); } } 执行的结果如下 C:\java\tmp> java testHeap 2031616 5578752 10498048 Time: 651 在这里,我们看到 totalMemory 不断的上升,当然,这是正常现象,但是实际上我们可以控制 JVM 一开始就抓取的记忆体大小,这样的好处是 JVM 一开始就抓取了大量的 Heap 。怎么做呢? 我们先用 java -X 来看看他有哪些额外的参数可以下,没错,我看到我感兴趣的几个参数 -Xms <size> set initial Java heap size -Xmx <size> set maximum Java heap size -Xss <size> set java thread stack size 接著,我想要让 JVM 一开始就抓取大量的记忆体,因此我选择 -Xms 这个参数,底下是我的执行结果: C:\java\tmp> java -Xms50000000 testHeap 49741824 49741824 49741824 Time: 480 这时候我们看到 total 的记忆体维持不变,原因很简单,因为 testHeap 使用记忆体的量,并没有超过我们一开始抓到的量。但是有一个很有趣的现象是回圈内的时间已经更短了,换一个角度来说,就是程式跑起来更有效率。这种以记忆体空间来换取执行时间的方式,也许并不是最棒的校调方法,但是却是一个在不修改程式码的方式下,提高效率的方法。当然,我们也可以限制记忆体的最大用量,参数则为 -Xmx 。一般说来,我并不建议您设定 -Xmx ,原因很简单,因为一旦您设定了 -Xmx ,那么 JVM 所抓取的记忆体量到了这个值之後,便不会再抓取记忆体,也就是说您的程式将无法执行,我们看看底下的结果 C:\java\tmp> java -Xmx5000000 testHeap 2031616 5578752 Exception in thread "main" java.lang.OutOfMemoryError C:\java\tmp> Hehe,这些参数的意义很明白嘛。当使用-Xdebug时,还有两个参数:-Xnoagent,-Djava.compiler=NONE,为非HotSpot使用。设定远程JVM的参数是-Xrunjdwp:transport=dt_socket,address=<port_num>,suspend=y,server=y to ender: 1.你的那篇文章《透过 Java 参数来改善 Java 效能》中的代码根本就不能编译。 2.-Xms,-Xmx,-Xss参数的使用好像没那么简单,我做了一个简单的实验,代码如下:import java.io.*;import java.util.*;public class test_mem_set{ public static void main(String args[]) { int i=0,i_size=0; String s1="asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf"+ "asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf"+ "asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf"+ "asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf"+ "asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf"+ "asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf"+ "asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf"+ "asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf"+ "asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf"+ "asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf"; String s2=""; Stack stk1=new Stack(); for(i=0;i<5*1024;i++) // { s2=i+"--"+s1; //s2大小约为1KB stk1.push(s2); } i_size=stk1.size(); System.out.println("size: "+i_size); System.out.println("element at 0: "+stk1.get(0)); System.out.println("element at 99: "+stk1.get(99)); System.out.println("element at 500: "+stk1.get(500)); System.out.println("element at 999: "+stk1.get(999)); //System.out.println("element at 4999: "+stk1.get(4999)); //System.out.println("element at 7000: "+stk1.get(7000)); //System.out.println("element at 9999: "+stk1.get(9999)); } } 我改变程序的for循环次数来改变程序运行时所需内存堆的大小,编译执行时指定-Xms或-Xmx或-Xss参数对程序是有一定影响,但不能精确控制该程序什么时候内存溢出,请问是什么原因? 3.听说JVM的内存堆的初始化设置是640KB,有没有这回事,我做实验好像不是这样。 4.-server参数和-client参数对程序运行的影响有多大(在Linux平台下)? 我要用堆栈和队列在多线程之间共享数据(它们从vector继承而来,是线程安全的),而这两种数据结构的容量和JVM的启动参数有关,我担心使用中出现内存溢出。 java -server 用在服务型的程序,如SOCKET SERVER,对安全和稳定性做了一定优化java -client 是默认选择,速度快,占用资源较少在win下,SUN JDK 新版本JVM默认时,可以使用64M, 旧版本是16M 。 当然你也可以通过指定参数,来修改内存配置-Xms<size> -Xmx<size> -Xss<size> 详细资料可以参考 forum.java.sun.com 上的相关栏目,内容很全! 顺便说一下,IBM的JDK和SUN的有所不同,这里有IBM JDK的一篇设置 堆大小 的文章,可以参考http://www.cn.ibm.com/developerWorks/java/tip-heap-size/index.shtml 正则表达:+ 关于switch语句的 关于LOG4J设置子类的问题~~~ 如何用java 写显示农历的程序? 有个jdbc的问题向大家请教?? 我是哈尔滨人 有一个项目 是我的毕业设计 我花人民币 找人指导我做 请JAVA高手指点:JAVA初学者应该看什么书,和JAVA的学习路线?有高分,QQ:4931851急!!急!!急!!! 紧急求助;关于xls新旧版不兼容问题。 又一个关于JAVA的问题,还是基本性质的题目,爱好者们进来研究研究 日期大小比较 和我说 说好吗? 请教:java 的启动参数。
第二、用处说得很清楚了啊……你不会告诉我你不会E文吧?
第三、一般情况下不怎么用这些参数……
我听说java虚拟机能使用的内存量和性能与启动参数有关,上面的英文解释那么简略,你光看这个就能优化系统性能???
从解释上来看有些参数挺有用,我想问问谁用过这些东西,到底有没有效果。
我们都知道, Java 在执行的时候会吃掉不少记忆体,而当记忆体不够
用的时候, JVM 会向系统要求更大的记忆体来使用。但是实际上对於 Ja
va 来说,我们会发现资料可以存在许多不同的地方,其中有两个重要的
是 Heap 以及 Stack 。这两者有什么差别,我们在以後会提到,但是在
这之前,我们先来看一个程式:
public class testHeap
{
public static void main(String argv[])
{
StringBuffer sb = new StringBuffer();
long starttime;
long endtime;
starttime = System.currentTimeMillis();
for(int i=0; i <=100000; i++)
{
sb.append(i).append("hello").append(i);
if(i % (100000/2) == 0)
{
System.out.println(Runtime.getRuntime().totalMe
mory());
}
}
endtime = System.currentTimeMillis();
System.out.println("Time: "+(endtime-starttim
e));
}
}
执行的结果如下
C:\java\tmp> java testHeap
2031616
5578752
10498048
Time: 651
在这里,我们看到 totalMemory 不断的上升,当然,这是正常现象,但
是实际上我们可以控制 JVM 一开始就抓取的记忆体大小,这样的好处是
JVM 一开始就抓取了大量的 Heap 。怎么做呢? 我们先用 java -X 来看
看他有哪些额外的参数可以下,没错,我看到我感兴趣的几个参数
-Xms <size> set initial Java heap size
-Xmx <size> set maximum Java heap size
-Xss <size> set java thread stack size
接著,我想要让 JVM 一开始就抓取大量的记忆体,因此我选择 -Xms 这
个参数,底下是我的执行结果:
C:\java\tmp> java -Xms50000000 testHeap
49741824
49741824
49741824
Time: 480
这时候我们看到 total 的记忆体维持不变,原因很简单,因为 testHea
p 使用记忆体的量,并没有超过我们一开始抓到的量。但是有一个很有趣
的现象是回圈内的时间已经更短了,换一个角度来说,就是程式跑起来更
有效率。这种以记忆体空间来换取执行时间的方式,也许并不是最棒的校
调方法,但是却是一个在不修改程式码的方式下,提高效率的方法。当然
,我们也可以限制记忆体的最大用量,参数则为 -Xmx 。一般说来,我并
不建议您设定 -Xmx ,原因很简单,因为一旦您设定了 -Xmx ,那么 JVM
所抓取的记忆体量到了这个值之後,便不会再抓取记忆体,也就是说您
的程式将无法执行,我们看看底下的结果
C:\java\tmp> java -Xmx5000000 testHeap
2031616
5578752
Exception in thread "main" java.lang.OutOfMemoryError
C:\java\tmp>
当使用-Xdebug时,还有两个参数:-Xnoagent,-Djava.compiler=NONE,为非HotSpot使用。设定远程JVM的参数是-Xrunjdwp:transport=dt_socket,address=<port_num>,suspend=y,server=y
1.你的那篇文章《透过 Java 参数来改善 Java 效能》中的代码根本就不能编译。
2.-Xms,-Xmx,-Xss参数的使用好像没那么简单,我做了一个简单的实验,代码如下:
import java.io.*;
import java.util.*;public class test_mem_set
{
public static void main(String args[])
{
int i=0,i_size=0;
String s1="asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf"+
"asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf"+
"asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf"+
"asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf"+
"asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf"+
"asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf"+
"asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf"+
"asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf"+
"asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf"+
"asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf12asdfasdf";
String s2="";
Stack stk1=new Stack();
for(i=0;i<5*1024;i++) //
{
s2=i+"--"+s1; //s2大小约为1KB
stk1.push(s2);
} i_size=stk1.size();
System.out.println("size: "+i_size);
System.out.println("element at 0: "+stk1.get(0));
System.out.println("element at 99: "+stk1.get(99));
System.out.println("element at 500: "+stk1.get(500));
System.out.println("element at 999: "+stk1.get(999));
//System.out.println("element at 4999: "+stk1.get(4999));
//System.out.println("element at 7000: "+stk1.get(7000));
//System.out.println("element at 9999: "+stk1.get(9999));
}
}
我改变程序的for循环次数来改变程序运行时所需内存堆的大小,编译执行时指定-Xms或-Xmx或-Xss参数对程序是有一定影响,但不能精确控制该程序什么时候内存溢出,请问是什么原因? 3.听说JVM的内存堆的初始化设置是640KB,有没有这回事,我做实验好像不是这样。 4.-server参数和-client参数对程序运行的影响有多大(在Linux平台下)?
java -client 是默认选择,速度快,占用资源较少在win下,SUN JDK 新版本JVM默认时,可以使用64M, 旧版本是16M 。 当然你也可以通过指定参数,来修改内存配置
-Xms<size>
-Xmx<size>
-Xss<size> 详细资料可以参考 forum.java.sun.com 上的相关栏目,内容很全!
http://www.cn.ibm.com/developerWorks/java/tip-heap-size/index.shtml