官术网_书友最值得收藏!

Sample code

The following sample code allocates an image array of size 999999 and loads images to it. Then, the code retrieves the image bytes and stores them to a byte array of size 999999.

On a heap size of 3,044 MB and region size of 1 MB, this code will force full G1 GC and eventually shut down the JVM with OutOfMemoryError:

import java.io.*; 
import java.awt.image.BufferedImage; 
import javax.imageio.ImageIO; 
public class TriggerG1FullGC { 
    final BufferedImage[] images = new BufferedImage[999999]; 
    final byte[][] imgByte = new byte[999999][]; 
 
    public TriggerG1FullGC() throws Exception { 
        for (int i = 0; i < 999999; i++) { 
            images[i] = ImageIO.read(new File("img.jpg")); 
        } 
        System.out.println("Images read"); 
 
        for (int i = 0; i < 999999; i++) { 
            ByteArrayOutputStream baos=new ByteArrayOutputStream(); 
            ImageIO.write(images[i], "jpg", baos ); 
            imgByte[i] = baos.toByteArray(); 
        } 
        System.out.println("Bytes read"); 
    } 
    public static void main(String... args) throws Exception { 
        new TriggerG1FullGC(); 
    } 
} 

You can execute the preceding code using the following command:

    > java -Xlog:gc* -Xlog:gc*:myG1log.log TriggerG1FullGC 

 

The preceding code will output GC logs to the console (by courtesy of -Xlog:gc*). It will also store the log to the myG1log.log file. The code (as we expected) will fail with OutOfMemoryError. Let's examine the contents of the GC log file.

Starting with Java 9, G1 is the default GC. So, the preceding code doesn't use any runtime options to specifically use G1.
主站蜘蛛池模板: 申扎县| 仲巴县| 尼勒克县| 土默特左旗| 杨浦区| 静海县| 全州县| 丰县| 达孜县| 晋中市| 大埔县| 冀州市| 南召县| 宜兰市| 周宁县| 昭通市| 报价| 逊克县| 平江县| 体育| 阿坝| 神农架林区| 涿鹿县| 隆尧县| 宁波市| 来凤县| 宜城市| 荃湾区| 城市| 安多县| 锡林浩特市| 孙吴县| 岐山县| 镇远县| 随州市| 礼泉县| 仙居县| 兴国县| 寿阳县| 电白县| 夏河县|