From: http://hi.baidu.com/dearfenix/blog/item/1b0ce80e64ca12ce7bcbe109.html
It has always been known that JVM heap size can be set, and Java programs are always written/debugged using eclipse. Run the program by adding parameters on the command line or console. Symptom: In the eclipse configuration file eclipse. set-vmargs-xms500m-xmx1024m in ini. Java still appears when you run or debug some memory-consuming programs in eclipse. lang. outofmemoryerror: Java heap space error, which is generally considered to be insufficient memory and insufficient memory for the Java Virtual Machine. Adding these parameters in the command line will be effective and will not cause errors. This indicates a problem where these parameters do not work at all.
Today, you need to debug the program in eclipse. Heap error occurs before debugging. You searched many places on the Internet and got the final answer:
Select the running class, click 'run-> Run... 'in the menu, and enter-xmx800m In the VM arguments box under the (x) = argument tab to save the running.
It turns out that you still need to set separate settings for each project, Khan...
Zz
There are three possible causes of outofmemoryerror. First, the JVM has a real memory leak, which causes a bug in the internal implementation of the JVM heap. This is extremely unreliable. All JVMs have been fully tested, and if someone finds this bug, it will definitely be the highest priority. Therefore, you can eliminate this possibility with great relief.
The second possible reason for outofmemoryerror is that you did not provide enough available memory for your application to run. In this case, there are two possible solutions, or increase the JVM heap available size, or reduce the total amount of memory required by your application. To increase the JVM available heap size, you can simply use the JVM-xmx parameter. If you set this parameter as large as possible (the maximum available memory should not exceed the physical memory of the system, otherwise your application will be paged and paused), there will still be the memory problems mentioned above, then, you need to reduce the amount of memory that your application may use. Reducing the application memory may be simple. You may allow some collections to be too large, such as using many large buffers. Or it is too complicated, requiring you to implement some classes and even redesign the application.
Reader jams stauffer points out that some JVMs (such as Sun's JVMs) also have a "perm" parameter to process JVM structures and class objects. If you are using a very large number of class sets, it may run outside the "perm" space, and then you need to increase the size of the space, for example, sun's JVM uses the-XX: permsize and-XX: maxpermsize options.
Third, outofmemoryerror is the most common and unintentional object reference persistence. You do not release objects clearly, so that your heap grows until you have no additional space.
Processing outofmemoryerror:
Is it a JVM internal bug? Unlikely. If so, this is the highest priority bug (Why have no one found it, but you have encountered it ?).
Is there enough memory allocated to the actual running application? Two options: Use the-xmx parameter to increase the maximum memory usage of the heap (or use the-XX: maxpermsize parameter to increase the size of the perm space ); or use a smaller set/buffer/tablespace/object ....., in order to reduce the total amount of memory required, that is, you can adjust the object size, redesign and re-implement your application process.
Unintentional object reference persistence? Find the source object that has not been referenced, change it, and release the object. The article outline in the IBM developer community reveals such a general process. This process mainly waits until the application reaches a constant state-you will expect the most newly created objects to be temporary objects and can be collected by the garbage collector. This is often after all the initialization work of the application is completed.
Forced garbage collection to get a heap object snapshot.
Doing any work may be importing to unintentional object reference persistence.
Forces another garbage collection and obtains the object snapshot of the second heap.
Compare the two snapshots to see which objects have increased in quantity from the first snapshot to the second snapshot. Because you force the garbage collection before the snapshot, the rest will be all objects referenced by the application, comparing two snapshots accurately identifies the newly created objects that are retained in the application.
Based on your understanding of the application, you can determine which objects are unintentionally retaining object references in two snapshot comparisons.
Track the leading references and find the objects that are referencing these unintentional holding objects until you find the source object that causes this problem.
When starting a virtual machine, add a parameter-xms800m-xmx800m.
-XMS <size>
Set the JVM initialization heap memory size
-Xmx <size>
Sets the maximum JVM heap memory size.
If it is an application, then: Java-xms800m-xmx800m your class name
For a web server such as Tomcat, add this parameter to the Startup file of the server.
In addition, set Environment Variables
Java_opts = "-server-xms800m-xmx800m-XX: permsize = 64 m-XX: maxnewsize = 256 m-XX: maxpermsize = 128 M-djava. AWT. Headless = true"