When does java trigger gc
##1. Memory recycling strategies and common concepts
Common memory recycling strategies can be understood from the following dimensions:1 Serial & Parallel
Serial: Single thread performs memory recycling work . It is very simple and does not need to consider issues such as synchronization, but it takes a long time and is not suitable for multiple CPUs. Parallel: Multiple threads perform recycling work concurrently. Suitable for multiple CPUs and highly efficient.2 Concurrency & stop the world
stop the world: The application thread in the jvm will hang, and only the garbage collection thread is working to clean up the garbage. Simple, no need to consider issues such as dirty recycling.Concurrency: While garbage collection is occurring, the application is also running. Ensure application response time. There may be situations where the recycling is not clean and requires secondary recycling.
3 Compressed & Uncompressed ©
Compression: After garbage collection, the surviving objects will be slid into a continuous space to clean up the fragments and ensure The remaining space is contiguous. Non-compressed: Keep fragments and do not compress. copy: Move the surviving objects to the new space and release all the old space. (Requires larger memory.) A garbage collection algorithm can be considered and designed from the above dimensions, and ultimately produce a garbage collector with different characteristics suitable for different scenarios.2. JVM’s YGC&FGC
YGC: GC the new generation heap. The frequency is relatively high because most objects have a short lifespan and are recycled in the new generation. The performance cost is small. FGC: Full heap-wide GC. FGC is triggered when the default heap space usage reaches 80% (adjustable). Taking our production environment as an example, FGC is generally triggered rarely, sometimes once every 10 days or about a week.3. When will YGC be triggered and when will FGC be triggered?
● Timing of YGC: Insufficient edn space● Timing of FGC: 1. Insufficient old space; 2. Insufficient perm space; 3. Display calls to System.gc(), including RMI, etc. Timing trigger;4.Pessimistic strategy during YGC;5.Dump live memory information (jmap –dump:live).For the triggering timing of YGC, it is quite obvious that there is insufficient eden space, and ygc will definitely be triggered at this time.
For the triggering timing of FGC, old Insufficient space, insufficient perm space, and calling system.gc() are relatively obvious. In this case, GC will generally be triggered.
The most complicated one is the so-called pessimistic strategy. The mechanism it triggers is to first calculate the average size of the previous promotion, that is, from the new generation, through ygc to the average size of the new generation, and then If the remaining space in the old generation is less than the promotion size, a FullGC will be triggered. The strategy considered by sdk is that from an average and long-term perspective, the possibility of insufficient promotion space next time is very high. Instead of waiting until then for fullGC, it is better to pessimistically believe that FullGC will definitely be triggered next time and directly execute FullGC first. And from the actual use process, it has also achieved a relatively stable effect. php Chinese website, a large number of freeJava introductory tutorials, welcome to learn online!
The above is the detailed content of When does java trigger gc. For more information, please follow other related articles on the PHP Chinese website!

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于结构化数据处理开源库SPL的相关问题,下面就一起来看一下java下理想的结构化数据处理类库,希望对大家有帮助。

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于PriorityQueue优先级队列的相关知识,Java集合框架中提供了PriorityQueue和PriorityBlockingQueue两种类型的优先级队列,PriorityQueue是线程不安全的,PriorityBlockingQueue是线程安全的,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于java锁的相关问题,包括了独占锁、悲观锁、乐观锁、共享锁等等内容,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于多线程的相关问题,包括了线程安装、线程加锁与线程不安全的原因、线程安全的标准类等等内容,希望对大家有帮助。

本篇文章给大家带来了关于Java的相关知识,其中主要介绍了关于关键字中this和super的相关问题,以及他们的一些区别,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于枚举的相关问题,包括了枚举的基本操作、集合类对枚举的支持等等内容,下面一起来看一下,希望对大家有帮助。

封装是一种信息隐藏技术,是指一种将抽象性函式接口的实现细节部分包装、隐藏起来的方法;封装可以被认为是一个保护屏障,防止指定类的代码和数据被外部类定义的代码随机访问。封装可以通过关键字private,protected和public实现。

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于设计模式的相关问题,主要将装饰器模式的相关内容,指在不改变现有对象结构的情况下,动态地给该对象增加一些职责的模式,希望对大家有帮助。


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

WebStorm Mac version
Useful JavaScript development tools

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),
