我正在开发一个化学应用程序,需要包括Avogadro的电话号码:
(602200000000000000000000
)
我真的不知道我是否可以使用科学记数法将其表示为6.022 x 10x23
(不能放入指数)。
我首先使用double
,然后使用long
,现在使用java.math.BigInteger
。
但是它仍然说它太大了,我该怎么办?或者这对于系统来说应该只是很多?
参考方案
首先,您需要检查您的物理/化学教科书。
Avogadro的人数不是602,200,000,000,000,000,000,000,000,000。大约是6.022 x1023。关键字是“大约”。截至2019年,精确值为6.02214076×1023 mol-1
(在2015年,当我最初写此回复时,当前对Avogadro数的最佳近似为6.022140857(74)×1023 mol-1,相对误差为+/- 1.2×10–8。在2019年,SI重新定义了该摩尔/ Avogadro的数字就是上面的精确值。来源:Wikipedia)
我最初的答案(2015年)是,由于数字只需要8位小数位精度,因此Java double
类型是表示它的合适类型。因此,我建议:
final double AVOGADROS_CONSTANT = 6.02214076E23;
显然,int
或long
都不能代表该数字。 float
可以但不具有足够的精度(假设我们使用最佳的可用测量值)。
现在(2019年后),BigInteger
是最简单的正确表示形式。
现在来看将常量声明为(不同)为double
,long
和BigInteger
的明显问题。
我希望你做了这样的事情:
double a = 602200000000000000000000;
等等。那是行不通的,但是需要解释它行不通的原因。问题在于该数字是作为int
文字提供的。 int
不能那么大。 int
的最大可能值是231-1 ...,比2 x 109大一点。
这就是Java编译器所抱怨的。文字太大,无法成为int
。
对于long
文字也太大了。 (算一算。)
但是对于double
文字来说,它并不太大...只要您正确编写它。
使用BigInteger(String)
的解决方案之所以有效,是因为它避免了通过使用字符串代替数字并将其表示为数字文字并在运行时进行解析的问题。从语言的角度来看这是可以的,但是(IMO)是错误的,因为额外的精度是一种错觉。
我想将BigInteger写入文件。做这个的最好方式是什么。当然,我想从输入流中读取(使用程序,而不是人工)。我必须使用ObjectOutputStream还是有更好的方法?目的是使用尽可能少的字节。谢谢马丁 参考方案 Java序列化(ObjectOutputStream / ObjectInputStream)是将对象序列化为八位字节序列的一种通用方法。但…
java:继承 - java有哪些替代继承的方法? java大神给出的解决方案 有效的Java:偏重于继承而不是继承。 (这实际上也来自“四人帮”)。他提出的理由是,如果扩展类未明确设计为继承,则继承会引起很多不正常的副作用。例如,对super.someMethod()的任何调用都可以引导您通过未知代码的意外路径。取而代之的是,持有对本来应该扩展的类的引用,然后委托给它。这是与Eric…
Java-如何将此字符串转换为日期? - java我从服务器收到此消息,我不明白T和Z的含义,2012-08-24T09:59:59Z将此字符串转换为Date对象的正确SimpleDateFormat模式是什么? java大神给出的解决方案 这是ISO 8601标准。您可以使用SimpleDateFormat simpleFormat = new SimpleDateFormat("yyyy-MM…
Java:从类中查找项目名称 - java仅通过类的实例,如何使用Java反射或类似方法查找项目名称?如果不是,项目名称(我真正想要的是)可以找到程序包名称吗? 参考方案 项目只是IDE使用的简单组织工具,因此项目名称不是类或JVM中包含的信息。要获取软件包,请使用Class#getPackage()。然后,可以调用Package#getName()将包作为您在代码的包声明中看到的String来获取…
JAVA 8具有任何匹配属性的对象的过滤器列表 - java我的要求是通过匹配任何属性的字符串来过滤对象列表。例如,假设Contact类具有三个属性:街道,城市,电话。我知道java流过滤器是如何工作的,在这里我必须将输入字符串与每个属性进行比较,如下所示:contactList.stream().filter(contact -> contact.getStreet().equals("dubai&…