java内存对齐_java内存参数对齐问题

最近在做JVM调优时发现个问题,感觉比较有趣,特记录下:

JVM参数配置:

-Xms2048m -Xmx2048m -XX:PermSize=256m -XX:MaxPermSize=512m -XX:+UseConcMarkSweepGC -XX:+PrintGCDetails -XX:+PrintTenuringDistribution

GC日志为

12083.607: [GC12083.607: [ParNew Desired survivor size 35782656 bytes, new threshold 6 (max 6)

- age 1: 186216 bytes, 186216 total

- age 2: 2328 bytes, 188544 total

- age 3: 21888 bytes, 210432 total

- age 4: 63880 bytes, 274312 total

- age 5: 63280 bytes, 337592 total

- age 6: 10588168 bytes, 10925760 total

: 574751K->15677K(629120K), 0.0072360 secs] 603265K->44191K(2027264K), 0.0074590 secs] [Times: user=0.12 sys=0.00, real=0.00 secs]

我们都知道默认情况下

NewRatio=2,NewRatio=Old/Yong=Old/(Eden+Survivor*2)

SurvivorRatio=8,SurvivorRatio=Eden/Survivor

TargetSurvivorRatio=0.5

根据上面的配置,Survivor的大小为 204810241024/3/10bytes=71582789,而日志中的 Desired survivor size(DSS)=SurvivorTargetSurvivorRatio=35782656,可以推算出Survivor=357826562=71565312,可以看到两个结果存在差异,那么原因在哪呢?

查看JVM的源码发现Survivor大小是这么计算的:

size_t compute_survivor_size(size_t gen_size, size_t alignment) const {

size_t n = gen_size / (SurvivorRatio + 2);

return n > alignment ? align_size_down(n, alignment) : alignment;

}

#define align_size_down_(size, alignment) ((size) & ~((alignment) - 1))

enum SomePublicConstants {

// Generations are GenGrain-aligned and have size that are multiples of

// GenGrain.

// Note: on ARM we add 1 bit for card_table_base to be properly aligned

// (we expect its low byte to be zero - see implementation of post_barrier)

LogOfGenGrain = 16 ARM_ONLY(+1),

GenGrain = 1 << LogOfGenGrain

};

原来计算survivor大小时,需要进行对齐操作;

71582789&~((1<<16)-1)=71565312

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值