JAVA 精度问题

精度问题:

double:小数点后15位

float:小数点后7位


一、数据类型

JAVA基本数据类型及之间的转换 - 小松松 - liusong0605 的博客

 

    1.布尔型(boolean) :true/false,不可以以0或非0的数字代替;不能进行数据之间的转换。

    2.整数类型
JAVA基本数据类型及之间的转换 - 小松松 - liusong0605 的博客

  ** 整型默认为int型,而long类型表示的范围要超出int表数范围,所以,声明long类型时,常量后要加L(l)。    

如:long l1=12345678  //  数值在int范围之内,还不会出错

       long l2=8888888888;//  数值在int范围之外,会出错

       long l3=8888888888L; //正确

3.浮点类型:
JAVA基本数据类型及之间的转换 - 小松松 - liusong0605 的博客
      * 浮点型默认为double,所以float类型声明时后面需要加f/F ; 或者用强制转换符。

  Float  f1=(float)0.1;

  Float  f2=0.1f;

  两者的区别:f1 为八个字节的double类型,强制转换为四个字节的float类型。

                       f2 本身就是四个字节的float类型。

4.字符型 (char)

  每个字符占两个字节;值放在“”里;

 

二、基本数据类型转换:

    各数据类型按容量大小(表数范围大小)由小到大排列为:

     Byte, short, char  ——int ——long——float——double

  1.转换时遵循的原则:

     1)容量小的类型自动转换为容量的类型;

     2)容量大的类型转换为容量小的类型时,要加强制转换符;

    3)byte,short,char之间不会互相转换,并且三者在计算时首先转换为int类型;

    4)实数常量默认为double类型, 整数常量默认为int类型;

    *  字符型 为什么也能和 整形、浮点型进行运算呢? 

       答:  字符型在机器内部也是数字。进行计算时,先获得字符的ASCK码,然后再进行计算。

 2.转换举例: 

     Int i1=123;

     Int i2=456;

     Double d1 = (i1+i2)*1.2             //容量小的类型自动转换为容量大的类型

     Float f1 = (float) (i1+i2)*1.2      //容量大的类型转换为小容量的类型时,需要加上强制转换符

 

      Byte b1=1;

      Byte b2=2;

      Byte b3=(byte)(b1+b2);        //byte,short,char在计算时首先转换为int,大容量(int)转换为小容量的类型(byte)时要加强制转换符



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中的简单浮点数类型float和double存在计算精度问题。这是因为在大多数编程语言中,包括Java在内,无法对浮点数进行精确运算。换句话说,浮点数的计算结果可能会存在一定的误差。这是由于浮点数的内部表示方式和计算机在处理浮点数时的舍入误差所导致的。 为了解决这个问题,可以使用Java提供的BigDecimal类来进行精确的浮点数运算。BigDecimal类可以处理任意位数的整数和小数,并且提供了加减乘除和四舍五入等常用操作。使用BigDecimal时,建议使用字符串来构造BigDecimal对象,以避免由于浮点数的内部表示方式引起的误差。 如果你需要进行浮点数的加减乘除和四舍五入等操作,可以使用工具类Arith来简化操作。Arith类提供了一系列静态方法,包括add、sub、mul、div和round等方法,可以方便地进行浮点数的精确计算。 因此,如果你在Java中遇到了浮点数计算精度问题,可以使用BigDecimal或Arith类来解决这个问题。这样可以确保计算结果的精度和准确性。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [在Java中实现浮点数的精确计算](https://blog.csdn.net/zhouysh/article/details/393561)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值