java native堆_Java Native Memory比堆更快吗?

执行IO时,直接内存更快,因为它可以避免一个数据副本.但是,对于95%的申请,您不会注意到差异.

您可以将数据存储在直接内存中,但是它不会比存储数据POJO快. (或安全,可读或可维护)如果您担心GC,请提前尝试创建对象(必须是可变的)并重复使用它们而不丢弃它们.如果您不丢弃对象,则无需收集任何内容.

Is Java native memory faster (I think this entails ByteBuffer objects?) than traditional heap memory when there are no serialization issues (for instance if I am comparing it with a huge byte[])?

如果使用像int这样的非字节,直接内存可能比使用byte []更快,因为它可以读取/写入整个四个字节而无需将数据转换为字节.

然而,它比使用POJO慢,因为它必须检查每次访问.

Or do the vagaries of garbage collection, etc. render this question unanswerable?

速度与GC无关. GC仅在创建或放弃对象时很重要.

顺便说一句:如果你最小化丢弃的物体数量并增加你的伊甸园尺寸,你可以防止长时间发生轻微的收集,例如一整天.

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值