java处理大数组_我应该如何处理Java中的大型数组?

我有一种算法,当前会分配很大的双精度数组,它会经常更新和搜索。数组的大小为N ^

2/2,其中N是算法在其上进行操作的行数。为了与算法周围的应用程序相关联,我还必须保留整个内容的副本。

当然,这对我的算法可以处理的行数施加了限制,因为我要应对堆的限制。到现在为止,我还没有要求使用该算法的人员更新-

Xmx设置以分配更多的空间,并且效果很好。但是,我现在遇到了一个真正的问题,我需要此数组的大小超出内存的大小。

我已经计划更改算法以减轻这种大型阵列的必要性,并在该领域中取得了一些可喜的结果。但是,这是对过程的根本更改,在达到我当前代码的高度完善的条件之前,还需要进行大量工作,该代码在生产中已经非常成功地运行了好几年了。

因此,当我完善我的新算法时,我想延长现有算法的寿命,这意味着要解决与分配庞大的double数组相关的堆限制。

我的问题是最好的处理方式是什么?我应该使用nio

FileChannel和MappedByteBuffer,还是有更好的方法。如果我确实使用nio方法,那么与相同大小的内存阵列相比,我希望获得什么样的性能提升?

谢谢

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值