仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 536|回复: 11
打印 上一主题 下一主题

[学习教程] 了解下JAVA的用java完成浮点数的准确盘算

[复制链接]
若相依 该用户已被删除
跳转到指定楼层
楼主
发表于 2015-1-18 11:23:22 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
自己的整个学习思路完全被老师的讲课思路所牵制,这样几节课听下来,恐怕自己的见解都应该是书里的知识点了,根本谈不上自身发现问题,分析问题,和解决问题能力的切实提高。
成绩的提出:
假如我们编译运转上面这个程序会看到甚么?
  1. publicclassTest{publicstaticvoidmain(Stringargs[]){System.out.println(0.05+0.01);System.out.println(1.0-0.42);System.out.println(4.015*100);System.out.println(123.3/100);}};
复制代码
你没有看错!了局的确是
0.060000000000000005
0.5800000000000001
401.49999999999994
1.2329999999999999
Java中的复杂浮点数范例float和double不克不及够举行运算。不但是Java,在别的良多编程言语中也有如许的成绩。在年夜多半情形下,盘算的了局是正确的,可是多试几回(能够做一个轮回)就能够试出相似下面的毛病。如今终究了解为何要有BCD码了。
这个成绩相称严峻,假如你有9.999999999999元,你的盘算机是不会以为你能够购置10元的商品的。
在有的编程言语中供应了专门的泉币范例来处置这类情形,可是Java没有。如今让我们看看怎样办理这个成绩。
四舍五进
我们的第一个反响是做四舍五进。Math类中的round办法不克不及设置保存几位小数,我们只能象如许(保存两位):
  1. publicdoubleround(doublevalue){returnMath.round(value*100)/100.0;}
复制代码
十分不幸,下面的代码其实不能一般事情,给这个办法传进4.015它将前往4.01而不是4.02,如我们在下面看到的
4.015*100=401.49999999999994
因而假如我们要做到准确的四舍五进,不克不及使用复杂范例做任何运算
java.text.DecimalFormat也不克不及办理这个成绩:
System.out.println(newjava.text.DecimalFormat("0.00").format(4.025));
输入是4.02
BigDecimal
在《EffectiveJava》这本书中也提到这个准绳,float和double只能用来做迷信盘算大概是工程盘算,在贸易盘算中我们要用java.math.BigDecimal。BigDecimal一共有4个够造办法,我们不体贴用BigInteger来够造的那两个,那末另有两个,它们是:
BigDecimal(doubleval)
TranslatesadoubleintoaBigDecimal.
BigDecimal(Stringval)
TranslatestheStringrepresentationofaBigDecimalintoaBigDecimal.
下面的API扼要形貌相称的明白,并且一般情形下,下面的那一个利用起来要便利一些。
我们大概想都不想就用上了,会有甚么成绩呢?比及出了成绩的时分,才发明下面哪一个够造办法的具体申明中有这么一段:
Note:theresultsofthisconstructorcanbesomewhatunpredictable.Onemight
assumethatnewBigDecimal(.1)isexactlyequalto.1,butitisactually
equalto.1000000000000000055511151231257827021181583404541015625.Thisisso
because.1cannotberepresentedexactlyasadouble(or,forthatmatter,as
abinaryfractionofanyfinitelength).Thus,thelongvaluethatisbeing
passedintotheconstructorisnotexactlyequalto.1,appearances
nonwithstanding.
The(String)constructor,ontheotherhand,isperfectlypredictable:new
BigDecimal(".1")isexactlyequalto.1,asonewouldexpect.Therefore,itis
generallyrecommendedthatthe(String)constructorbeusedinpreferenceto
thisone.
本来我们假如必要准确盘算,非要用String来够造BigDecimal不成!在《EffectiveJava》一书中的例子是用String来够造BigDecimal的,可是书上却没有夸大这一点,这大概是一个小小的掉误吧。
<p>
JAVA学习必须明确这是一项投资,对于大多数的人来说,学习JAVA是为了就业,还有就是刚走向工作位置的朋友想尽快赶上工作的节奏。
不帅 该用户已被删除
沙发
发表于 2015-1-20 23:26:08 | 只看该作者
你就该学一学Servlet了。Servlet就是服务器端小程序,他负责生成发送给客户端的HTML文件。JSP在执行时,也是先转换成Servlet再运行的。虽说JSP理论上可以完全取代Servlet,这也是SUN推出JSP的本意,可是Servlet用来控制流程跳转还是挺方便的,也令程序更清晰。接下来你应该学习一下Javabean了,可能你早就看不管JSP在HTML中嵌Java代码的混乱方式了,这种方式跟ASP又有什么区别呢?
柔情似水 该用户已被删除
板凳
发表于 2015-1-26 23:12:59 | 只看该作者
Pet Store.(宠物店)是SUN公司为了演示其J2EE编程规范而推出的开放源码的程序,应该很具有权威性,想学J2EE和EJB的朋友不要 错过了。
老尸 该用户已被删除
地板
发表于 2015-2-4 21:25:34 | 只看该作者
Java 不同于一般的编译执行计算机语言和解释执行计算机语言。它首先将源代码编译成二进制字节码(bytecode),然后依赖各种不同平台上的虚拟机来解释执行字节码。从而实现了“一次编译、到处执行”的跨平台特性。
谁可相欹 该用户已被删除
5#
发表于 2015-2-5 11:41:24 | 只看该作者
让你能够真正掌握接口或抽象类的应用,从而在原来的Java语言基础上跃进一步,更重要的是,设计模式反复向你强调一个宗旨:要让你的程序尽可能的可重用。
小女巫 该用户已被删除
6#
发表于 2015-2-6 13:17:05 | 只看该作者
是一种使用者不需花费很多时间学习的语言
变相怪杰 该用户已被删除
7#
发表于 2015-2-16 06:36:08 | 只看该作者
学Java必读的两个开源程序就是Jive和Pet Store.。 Jive是国外一个非常著名的BBS程序,完全开放源码。论坛的设计采用了很多先进的技术,如Cache、用户认证、Filter、XML等,而且论坛完全屏蔽了对数据库的访问,可以很轻易的在不同数据库中移植。论坛还有方便的安装和管理程序,这是我们平时编程时容易忽略的一部份(中国程序员一般只注重编程的技术含量,却完全不考虑用户的感受,这就是我们与国外软件的差距所在)。
精灵巫婆 该用户已被删除
8#
发表于 2015-3-1 18:02:59 | 只看该作者
那么我书也看了,程序也做了,别人问我的问题我都能解决了,是不是就成为高手了呢?当然没那么简单,这只是万里长征走完了第一步。不信?那你出去接一个项目,你知道怎么下手吗,你知道怎么设计吗,你知道怎么组织人员进行开发吗?你现在脑子里除了一些散乱的代码之外,可能再没有别的东西了吧!
莫相离 该用户已被删除
9#
发表于 2015-3-2 17:47:09 | 只看该作者
是一种由美国SUN计算机公司(Sun Microsystems, Inc.)所研究而成的语言
飘灵儿 该用户已被删除
10#
发表于 2015-3-11 04:48:02 | 只看该作者
是一种使网页(Web Page)产生生动活泼画面的语言
若相依 该用户已被删除
11#
 楼主| 发表于 2015-3-17 20:53:20 | 只看该作者
Sun公司看见Oak在互联网上应用的前景,于是改造了Oak,于1995年5月以Java的名称正式发布。Java伴随着互联网的迅猛发展而发展,逐渐成为重要的网络编程语言。
乐观 该用户已被删除
12#
发表于 2015-3-25 01:34:50 | 只看该作者
是一种突破用户端机器环境和CPU
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2024-11-15 11:41

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表