-
JEP
-
Resolution: Delivered
-
P2
-
Thomas Schatzl
-
Feature
-
Open
-
Implementation
-
-
S
-
S
-
363
Summary
Remove the Concurrent Mark Sweep (CMS) garbage collector.
Non-Goals
- It is not a goal to remove any other garbage collector.
- It is not a goal to remove the CMS garbage collector from releases prior to the release to which this JEP is targeted.
Motivation
More than two years ago in, JEP 291, we deprecated the CMS collector for removal in a future release, in order to accelerate the development of other collectors. During this time, no credible contributors stepped up to take on the maintenance of CMS.
During this time we’ve also seen the introduction of two new collectors, ZGC and Shenandoah, along with further improvements to G1, which has been the intended successor to CMS since JDK 6. At this point the garbage collectors available in the Hotspot JVM, if they do not surpass CMS’s performance, have a small enough overhead that it is now safe to remove CMS. We expect that future improvements to the existing collectors will reduce the need for CMS even further.
Description
This change will disable compilation of CMS, remove the contents of the gc/cms
directory in the source tree, and remove options that pertain solely to CMS. References to CMS in the documentation will also be purged. Tests that try to use CMS will be removed or adapted as necessary.
Trying to use CMS via the -XX:+UseConcMarkSweepGC
option will result in the following warning message:
Java HotSpot(TM) 64-Bit Server VM warning: Ignoring option UseConcMarkSweepGC; \
support was removed in <version>
and the VM will continue execution using the default collector.
Alternatives
The code for CMS could be kept in the repository but not compiled. Without a maintainer, however, the code would become obsolete quickly yet might give a false impression of being supported.
Users can move to the G1 garbage collector or any of the other collectors. Users that absolutely require CMS may still use it for as long as it remains supported in earlier releases.
- relates to
-
JDK-8226197 Reduce G1’s CPU cost with simplified write post-barrier and disabling concurrent refinement
- Open
-
JDK-8226731 Remove StoreLoad in G1 post barrier
- Open
-
JDK-8017163 G1: Refactor remembered sets
- Resolved
-
JDK-8233280 Remove GCLockerInvokesConcurrent
- Resolved
-
JDK-8234020 Remove FullGCCount_lock
- Resolved
-
JDK-8245030 CardTable::precleaned_card is unused
- Resolved
-
JDK-8142518 JEP 291: Deprecate the Concurrent Mark Sweep (CMS) Garbage Collector
- Closed
-
JDK-8229373 Reserve more than MaxHeapSize for the heap to fight humongous object fragmentation in G1
- Open
-
JDK-8232365 Implementation for JEP 363: Remove the Concurrent Mark Sweep (CMS) Garbage Collector
- Resolved
-
JDK-8073188 Remove disable of old MSVC++ warning C4786
- Closed
-
JDK-8233382 Implementation for JEP 363: Remove the Concurrent Mark Sweep (CMS) Garbage Collector
- Closed