1、按照jvm的設計規則,JVM內存分為堆(Heap)和非堆(Non-heap)內存
"Java 虛擬機具有一個堆,堆是運行時數據區域,所有類實例和數組的內存均從此處分配。堆是在 Java 虛擬機啟動時創建的。","在JVM中堆之外的內存稱為非堆內存(Non-heap memory)"。可以看出JVM主要管理兩種類型的內存:堆和非堆。簡單來說堆就是Java代碼可及的內存,是留給開發人員使用的;非堆就是JVM留給自己用的,所有用到的方法區、JVM內部處理或優化所需的內存(如JIT編譯后的代碼緩存)、每個類結構(如運行時常數池、字段和方法數據)以及方法和構造方法的代碼都在非堆內存中。
(1)堆內存分配
JVM初始分配的內存由-Xms指定,默認是物理內存的1/64;JVM最大分配的內存由-Xmx指定,默認是物理內存的1/4。默認空余堆內存小於40%時,JVM就會增大堆直到-Xmx的最大限制;空余堆內存大於70%時,JVM會減少堆直到-Xms的最小限制。因此服務器一般設置-Xms、-Xmx相等以避免在每次GC 后調整堆的大小。
(2)非堆內存分配
JVM使用-XX:PermSize設置非堆內存初始值,默認是物理內存的1/64;由XX:MaxPermSize設置最大非堆內存的大小,默認是物理內存的1/4。
2、根據上面的分析已經了解到JVM內存包含兩種:堆內存和非堆內存,另外JVM最大內存首先取決於實際的物理內存和操作系統,-Xmx的值和-XX:MaxPermSize的總和超過了JVM內存的最大限制,比如當前操作系統最大內存限制,或者實際的物理內存等等。說到實際物理內存這里需要說明一點的是,如果你的內存是1024MB,但實際系統中用到的並不可能是1024MB,因為有一部分被硬件占用了。
參考:http://blog.sina.com.cn/s/blog_59d8af510100y6gz.html
我使用的是myeclipse10自帶的Tomcat6,因為涉及到數據庫數據的導入導出,因此經常報出Out Of Memery 或則 Could not reserve enough space for object heap的問題。
a),Out Of Memery是內存溢出,通常是在程序運行過程中拋出的錯誤,當我們不斷的通過new創建實例時,顯然這是我們的堆內存不夠用了,這時只需將-Xmx和-Xms同時增大即可(到底能加多大,下面再說)。
b),Could not reserve enough space for object heap,無法實例化,這也是在程序運行過程中拋出的錯誤,根據上面的介紹,我們知道這是JVM的非堆內存不夠造成的,因此我們需要將XX:MaxPermSize的值是當增大。
c),無法啟動虛擬機,通常情況下這是因為我們的內存配置的不合理。
我們可以在DOS命令行下,輸入>java -XmxXXXXM -version來查看系統還有JDK最大管理的內存大小(不是越大越好哦),XXXX指代具體的值。不同的JDK,可管理的內存空間大小不一樣。

參考:http://blog.sina.com.cn/s/blog_56d8ea900100c3tf.html。
