轉自:http://www.cdtarena.com/javapx/201305/8674.html
如果在運行Java程序時出現以下的棧跟蹤信息:
Java代碼:
java.sql.SQLException: java.lang.OutOfMemoryError: Java heap space
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1073)
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:987)
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:982)
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:927)
at com.mysql.jdbc.Util.handleNewInstance(Util.java:435)
at com.mysql.jdbc.PreparedStatement.getInstance(PreparedStatement.java:872)
說明程序耗盡了JVM能夠使用操作系統的最大內存。
此時可以檢查代碼是否有過度創建對象的嫌疑。如果沒有,可以在java命令行中使用非標準的選項
Command代碼:
-Xmsp
-Xmxp
(-Xms 和 -Xmx 的第一個X必須大寫,否則無法辨認)
第一個參數指定初始內存大小,比如設置成5M,-Xms5m .(m或M都行)
第二個參數指定最大內存,即JVm能夠從操作系統中獲取的最大內存值。比如設置成10M -Xmx10m .
一般初始大小值小於最大值。 -Xms < -Xmx
一個簡單的例子:
Command代碼:
java -Xms128m -Xmx256m