標籤:操作 調用 .com 通過 程式 儲存空間 指標 儲存 常量池
在Myeclipse中測試restful介面返回資料的時候,直接採用main方法執行程式,但是幾秒鐘後程式報錯,返回字串結果正常,只是資料量有點大。
先查看原始碼Arrays.java:2367
建立char數組對象時候報錯,錯誤資訊堆空間溢出
華麗的分割線,下面堆和棧的解釋還是比較清楚的
◆寄存器:我們在程式中無法控制
◆棧:存放基本類型的資料和對象的引用,但對象本身不存放在棧中,而是存放在堆中(new 出來的對象)
◆堆:存放用new產生的資料
◆靜態域:存放在對象中用static定義的靜態成員
◆常量池:存放常量
◆非RAM儲存:硬碟等永久儲存空間
從堆和棧的功能和作用來通俗的比較,堆主要用來存放對象的,棧主要是用來執行程式的。
所有的方法調用都是通過棧來進行的,所有的局部變數,形式參數都是從棧中分配記憶體空間的。
JVM是基於堆棧的虛擬機器,JVM為每個新建立的線程都分配一個堆棧,也就是說,對於一個Java程式來說,它的運行就是通過對堆棧的操作來完成的。堆棧以幀為單位儲存線程的狀態,JVM對堆棧只進行兩種操作:以幀為單位的壓棧和出棧操作。
當線程啟用一個Java方法JVM就會線上程的Java堆棧裡新壓入一個幀,這個幀自然成為了當前幀。在此方法執行期間,這個幀將用來儲存參數、局部變數、中間計算過程和其他資料。
每一個Java應用都唯一對應一個JVM執行個體,每一個執行個體唯一對應一個堆。應用程式在運行中所建立的所有類執行個體或數組都放在這個堆中,並由應用所有的線程共用.Java中分配堆記憶體是自動初始化的。Java中所有對象的儲存空間都是在堆中分配的,但是這個對象的引用卻是在棧中分配,也就是說在建立一個對象時從兩個地方都分配記憶體,在堆中分配的記憶體實際建立這個對象,而在堆棧中分配的記憶體只是一個指向這個堆對象的指標(引用)。
Java把記憶體劃分成兩種:一種是棧記憶體,一種是堆記憶體。
在函數中定義的一些基本類型的變數和對象的引用變數都在函數的棧記憶體中分配。
堆記憶體用來存放由new建立的對象和數組。
棧的優勢是,存取速度比堆要快,僅次於寄存器,棧資料可以共用。
缺點是,存在棧中的資料大小與生存期必須是確定的,缺乏靈活性。
下面是解決方案
選擇Run Configuration或者Debug Configurations在VM arguments中設定參數 -Xms128m -Xmx512m
參數的含義
-vmargs -Xms128M -Xmx512M -XX:PermSize=64M -XX:MaxPermSize=128M
-vmargs 說明後面是VM的參數,所以後面的其實都是JVM的參數了
-Xms128m JVM初始分配的堆記憶體
-Xmx512m JVM最大允許分配的堆記憶體,按需分配
-XX:PermSize=64M JVM初始分配的非堆記憶體
-XX:MaxPermSize=128M JVM最大允許分配的非堆記憶體,按需分配
Preferences-->Java-->Installed JREs編輯正在使用中的jdk,
在Default VM Arguments中設定參數 -Xms128m -Xmx512m
java.lang.OutOfMemoryError: Java heap space