当前位置: 首页 > news >正文

伊宁网站建设wordpress菜单不能打开

伊宁网站建设,wordpress菜单不能打开,世界500强企业排名中国名单,做淘宝客网站赚钱吗目录 API 1.0 BigDecimal 类说明 1.1 为什么浮点数会计算不精确呢? 1.2 如何创建 BigDecimal 类型的对象 1.2.1具体来介绍三种方式来创建: 1.2.2 结合三种创建方法,一起来分析一下。 1.3 BigDecimal 类中的 valueOf(Strin…

目录

API                

        1.0 BigDecimal 类说明

        1.1 为什么浮点数会计算不精确呢?

        1.2  如何创建 BigDecimal 类型的对象

                1.2.1具体来介绍三种方式来创建:

                1.2.2 结合三种创建方法,一起来分析一下。 

        1.3 BigDecimal 类中的 valueOf(String str) 方法

        1.4 BigDecimal 类中的 add() 方法(加减乘除的操作都是一样的,就不多赘述了)

        1.5 BigDecimal 类中的 doubleValue() 方法


API                

        1.0 BigDecimal 类说明

        BigDecimal 类是Java中用于精确表示大数的类,可以进行精确的数值运算。在需要精确计算的场景中,可以使用 BigDecimal 类来避免由于浮点数计算误差导致的计算结果不准确的问题。

        1.1 为什么浮点数会计算不精确呢?

代码如下:

public class Text {public static void main(String[] args) {double data1 = 0.1;double data2 = 0.2;System.out.println(data1+data2);}
}

运行代码如下:

        结果不是0.3,显然结果跟我们预想的不一样。当然不是所以的浮点数运行出来的结果都是错误的,只是有这一部分是运行出来的结果是错误的,但是这一部分我们作为合格的程序员来说是不能接收的。

          浮点数在计算机中的表示方式是通过将数值分为两部分:尾数和指数。尾数用来表示数值的有效位数,而指数用来表示数值的大小范围。然而,由于计算机内存的限制,尾数和指数都只能用有限的位数来表示,这就导致了浮点数的精度有限。

  1. 二进制表示:计算机使用二进制来表示浮点数,而大部分十进制数无法精确转换为二进制表示。例如,0.1(十进制)在二进制表示中是一个无限循环的小数0.00011001100110011...,因此在计算机中只能近似表示。

  2. 有限的位数:浮点数的尾数和指数都只能用有限的位数来表示,这就导致了浮点数的精度有限。例如,Java中的double类型只能精确表示15位有效数字,超过这个范围的数字会被截断或四舍五入。

  3. 浮点数运算误差:在进行浮点数运算时,由于尾数和指数的有限位数表示,计算机无法精确表示所有的运算结果。这就导致了浮点数运算的结果可能存在一定的误差。

  4. 舍入误差:在将一个浮点数转换为二进制表示时,可能会存在舍入误差。例如,一个无限循环的小数在转换为二进制表示时会被截断或四舍五入,从而导致精度损失。 

        1.2  如何创建 BigDecimal 类型的对象

                1.2.1具体来介绍三种方式来创建:

1.代码如下: 

import java.math.BigDecimal;public class BigDecimalMethod1 {public static void main(String[] args) {//先定义了两个基本数据类型,我们知道//0.1 + 0.2 在double 类型运行是不精确的double data1 = 0.1;double data2 = 0.2;//由基本数据类型转变为引用类型//利用自动装箱,在等号后面可以直接写基本数据类型,它会自动装箱Double d1 = data1;Double d2 = data2;//将Double类型转变为String类型//利用Double类型实例方法toString()String s1 = d1.toString();String s2 = d2.toString();//利用构造器传进字符串来创建对象,//由字符串类型转变为BigDecimal类型BigDecimal b1 = new BigDecimal(s1);BigDecimal b2 = new BigDecimal(s2);//BigDecimal类中的实例方法 add()方法,//将两个BigDecimal类型相加BigDecimal c = b1.add(b2);//调用BigDecimal的实例方法 doubleValue(),//将BigDecimal类型转变为基本数据类型double a = c.doubleValue();//+1是为了表达a是浮点型,不是字符串System.out.println(a+1);}}

运行结果如下:

 

 

2.代码如下:

import java.math.BigDecimal;public class BigDecimalMethod2 {public static void main(String[] args) {//先定义了两个基本数据类型,我们知道//0.1 + 0.2 在double 类型运行是不精确的double data1 = 0.1;double data2 = 0.2;//直接调用Double类中的静态方法toString(),//转变为字符串String s1 = Double.toString(data1);String s2 = Double.toString(data2);//利用有参数的构造器,传入字符串创建对象BigDecimal b1 = new BigDecimal(s1);BigDecimal b2 = new BigDecimal(s2);//BigDecimal类中的实例方法 add()方法,//将两个BigDecimal类型相加BigDecimal c = b1.add(b2);//调用BigDecimal的实例方法 doubleValue(),//将BigDecimal类型转变为基本数据类型double a = c.doubleValue();//+1是为了表达a是浮点型,不是字符串System.out.println(a + 1);}}

运行结果如下:

 3.代码如下:

import java.math.BigDecimal;public class BigDecimalMethod3 {public static void main(String[] args) {//先定义了两个基本数据类型,我们知道//0.1 + 0.2 在double 类型运行是不精确的double data1 = 0.1;double data2 = 0.2;//这个就更加直接了,直接用BigDecimal中静态方法,//将浮点数类型转变为BigDecimal类型BigDecimal b1 = BigDecimal.valueOf(data1);BigDecimal b2 = BigDecimal.valueOf(data2);//BigDecimal类中的实例方法 add()方法,//将两个BigDecimal类型相加BigDecimal c = b1.add(b2);//将BigDecimal类型转变为浮点数类型double a = c.doubleValue();//+1是为了表达a是浮点型,不是字符串System.out.println(a+1);}
}

运行代码如下:

                1.2.2 结合三种创建方法,一起来分析一下。 

         第一种方式与第二种方式都是通过浮点型转变为字符串,然后再通过构造器转入字符串来创建BigDecimal 类型的对象,二者的区别在于有无创建Double对象,第一种是通过创建对象得到实例方法 toString() 将浮点型转变为字符串,而第二种没有创建Double对象,直接用Double类的静态方法 toString() 将浮点型转变为字符串。这两种方式的历程是由 浮点数 - 字符串 - BigDecimal类型。

        第三种是直接调用BigDecimal 类中的静态方法来创建对象,历程是 浮点数 - BigDecimal类型。事实上,第三种是第二种的封装。即JAVA中为了方便,为了效率,将第二种的长串的代码“封装”成第三种方法。

 

        1.3 BigDecimal 类中的 valueOf(String str) 方法

        通过传进字符串来创建方法,由于上面有详细讲到,就不多赘述了。

        1.4 BigDecimal 类中的 add() 方法(加减乘除的操作都是一样的,就不多赘述了)

         两个BigDecimal 类型的对象进行相加,得到总和。

代码如下:

import java.math.BigDecimal;public class Text {public static void main(String[] args) {double data1 = 0.1;double data2 = 0.2;BigDecimal b1 = BigDecimal.valueOf(data1);BigDecimal b2 = BigDecimal.valueOf(data2);BigDecimal c = b1.add(b2);System.out.println(c);}
}

运行结果:

         其他运算的方法:

                减法 subtract(),乘法 multiply(),除法 divide()

                其中 divide()还可以指定小数点后的几位数。

代码如下:

import java.math.BigDecimal;public class Text {public static void main(String[] args) {double data1 = 0.1;double data2 = 0.3;BigDecimal b1 = BigDecimal.valueOf(data1);BigDecimal b2 = BigDecimal.valueOf(data2);BigDecimal c = b1.divide (b2,5);System.out.println(c);}
}

运行结果:

        假如0.1/0.3 不去指定位数的时候,会报错。

import java.math.BigDecimal;public class Text {public static void main(String[] args) {double data1 = 0.1;double data2 = 0.3;BigDecimal b1 = BigDecimal.valueOf(data1);BigDecimal b2 = BigDecimal.valueOf(data2);BigDecimal c = b1.divide (b2);System.out.println(c);}
}

运行结果:

        1.5 BigDecimal 类中的 doubleValue() 方法

        BigDecimal 类型转变为 double 类型。

代码如下:

import java.math.BigDecimal;public class Text {public static void main(String[] args) {double data1 = 0.1;double data2 = 0.3;BigDecimal b1 = BigDecimal.valueOf(data1);BigDecimal b2 = BigDecimal.valueOf(data2);BigDecimal c = b1.add (b2);double a = c.doubleValue();System.out.println(a);}
}

运行结果如下:

      



http://www.yayakq.cn/news/513745/

相关文章:

  • 专做恐怖片的网站常州设计网站
  • it美工做网站做物流哪个网站推广效果好
  • 怎么上传网站数据库无锡网站优化价格
  • 沧州英文网站制作沈阳网站 房小二
  • 机械网站建设营销网页背景图片适合网页
  • 创世网站建设公司产品展示网站php源码
  • 运城市网站建设a5创业网站建设
  • 搭建网站哪个好岳阳网站设计公司
  • 北京做网站电话做网站用windows还是linux
  • 建设银行网站的安全措施网站建设开公司现在好做吗
  • 纯文本网站建设网站加水印
  • 总代理大型网站建设昆明网站排名优化公司哪家好
  • 手机网站的优缺点惠州网站开发公司电话
  • 深圳做宣传网站的公司网站 head关键字 密度 多少字
  • 自助建站网站重庆百度地图都导航不出来的
  • 大连凯杰建设有限公司网站杭州做网站小芒
  • 廊坊网站关键词优化北京网络职业学院
  • 深圳仿站定制模板建站网站建设与管理职业分析
  • 建筑公司网站被投诉违反广告法青岛市建设监理网站
  • 网站建设与制作流程广广东网站建设
  • asp.net做毕业设计网站重庆哪里有做网站的公司
  • 淮南市网站建设口碑营销名词解释
  • 微网站如何做宣传cn域名知名网站
  • 爱站网seowordpress添加二级踩点
  • 国际知名的论文网站北京学习网站建设
  • 做昆特牌的网站自己在公司上班做网站宣传 侵权吗
  • 乌克兰设计网站建设郑州同济医院妇科怎么样
  • asp网站下载百度提交收录入口
  • 广州企业网站建站巨人科技网站建设
  • 深圳建设品牌网站郑州百度seo排名公司