CMSPermGenSweepingEnabled vs CMSClassUnloadingEnabled

I've kind of asked this question before - What does JVM flag CMSClassUnloadingEnabled actually do?, but this time it's slightly different!

If I start a Java VM with the -XX:+CMSPermGenSweepingEnabled flag set, the following message is printed:

Please use CMSClassUnloadingEnabled in place of CMSPermGenSweepingEnabled in the future

The -XX:+CMSPermGenSweepingEnabled flag is often used to mitigate against PermGen OutOfMemory errors, however I have read elsewhere that people have found that by following the above advice they have still had these errors, but by sticking with -XX:+CMSPermGenSweepingEnabled as well as -XX:+CMSClassUnloadingEnabled their VM has stayed up longer between restarts.

Does -XX:+CMSClassUnloadingEnabled really supersede -XX:+CMSPermGenSweepingEnabled or is there still some benefit in having them both?

Thanks in advance

Rich ps: I know that the root cause of perm gen issues is still usually Classloader leaks, this is more about the message that the JVM produces if we use the above options.


From what I can tell, the only thing that the 1.6 JVM does with CMSPermGenSweepingEnabled is to print that message - it's not processed the way it is in 1.5. For CMSClassUnloadingEnabled to have any impact, UseConcMarkSweepGC must also be set.

Download the JDK source code (which includes hotspot) and inspecthotspot/src/share/vm/runtime/globals.hppCMSPermGenSweepingEnabled is present in 1.5 and absent in 1.6. In addition, the 1.6 version of hotspot/src/share/vm/runtime/arguments.cpp contains new code for printing the message. –  kschneid  Sep 16 '10 at 14:11
this is helpful –  hvgotcodes  Oct 19 '10 at 0:46
Ok looking to the jdk 1.6.23 source code didn't find any place of usage except globals.hpp where it is just set to false. So it is really used??? Sorry if i missed the place where it is used. –  user253202  Apr 13 '11 at 14:49



你可能感兴趣的:(java,jvm,jdk,ClassLoader,user,printing)