你如何使用Java真正的大布尔数组? [英] How do you make REALLY large boolean arrays using Java?

查看:358
本文介绍了你如何使用Java真正的大布尔数组?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

当我试图让使用Java一个非常大的布尔数组,如:

When I try to make a very large boolean array using Java, such as:

    boolean[] isPrime1 = new boolean[600851475144];

我得到precision错误的可能的损失?

I get a possible loss of precision error?

是不是太大了?

推荐答案

要储存600的十亿的位,需要75绝对最低的地址空间的千兆字节的!祝你好运!

To store 600 billion bits, you need an absolute minimum address space of 75 gigabytes! Good luck with that!

更糟的是,Java规范并未指定一个布尔阵列将使用一个单独的内存位的每个元素 - 它可能(的在某些情况下确实)使用更多的

Even worse, the Java spec doesn't specify that a boolean array will use a single bit of memory for each element - it could (and in some cases does) use more.

在任何情况下,我承认从项目欧拉#3 该号码。如果需要那么多的内存,你这样做是错误的...

In any case, I recognise that number from Project Euler #3. If it needs that much memory, you're doing it wrong...

这篇关于你如何使用Java真正的大布尔数组?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆