java浮点型数据类型分为_java中的浮点型数据类型有哪几种

java中的浮点型数据类型有哪几种

发布时间:2020-06-23 14:14:45

来源:亿速云

阅读:67

作者:元一

这篇文章将为大家详细讲解有关java中的浮点型数据类型,文章内容质量较高,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

浮点型首先明确java中浮点型数据类型主要有:单精度float、双精度double

至于浮点型就是跟int ,string类型差不多。都是数据类型。

浮点型(Floating-Point Types):简单说就是小数类型,小数点可以在相应的二进制的不同位置浮动。也就是人们知道的实数(real),当计算的表达式有精度要求时被使用。例如,计算平方根,或超出人类经验的计算如正弦和余弦,它们的计算结果的精度要求使用浮点型。Java 实现了标准(IEEE-754 )的浮点型和运算符集。有2种浮点型,单精度浮点型(float )及双精度(double )浮点型。

浮点型常量 Java的实常数有两种表示形式:1、 十进制数形式:由数字和小数点组成,且必须有小数点,如0.123 , 123.0

2、科学计数法形式:如:123e3或123E3,其中e或E之前必须有数字,且e或E后面的指数必须为整数(当然也包括负整数)。

科学计数法中的E

了解浮点型常量 Java的实常数有两种表示形式之后,很有必要给各位科普科普下科学计数法中E的面貌了~E是指数的意思,E代表的英文是exponent,E表示10的多少次方的意思。

比如7.823E5 = 782300 这里E5表示10的5次方,再比如54.3E-2 = 0.543这里E-2表示10的-2次方

再补充一点(针对负次方理解)一个数的负几次方就是这个数的几次方的倒数。

比如: 2的负1次方=2的1次方分之一=1/2

比如: 3的负2次方=3的2次方分之一=1/9

双精度浮点数(double)双精度浮点数在机内占8个字节、有效数字16位、表示范围:-1.79E+308 ~ +1.79E+308

double的精度太低,不适合用于做财务软件,财务涉及到钱的问题,要求精度较高,所以在java中有一个基础的类库名为:java.math.BigDecimal,但这个BigDecimal类型是引用类型不是基础类型,切记!!!

在讲单精度浮点数(float)的时候,差不多顺道把double之间的区别讲了哈哈,所以最后给张很经典的图片“敷衍敷衍”下,哈哈哈 ~哎哎哎..别打...别打...别打脸QAQ~

dddfb8f19b782dd821416ad0bc88f371.png

单精度浮点数(float)单精度浮点数在机内占4个字节、有效数字8位、表示范围:-3.40E+38 ~ +3.40E+38

在Java语言当中,所有的浮点型字面值 ~【V8提示】浮点型简单来说就是表示带有小数的数据~ 默认当做double类型来处理,要想该字面值当做float类型来处理,需要在字面值后面添加F/f,或者强制装换为float。具体如下代码:public static void main(String[] args) {

//3.10是浮点型,浮点型字面值默认当做double类型来处理,直接编译通过;

double d=3.10;

//3.10是浮点型,则必须加 F或者f,若没加,直接编译不通过,会报错“损失精度”

float f=3.10; //编译出错会报错“损失精度”

// 解决办法:

// 第一种方式:强制类型转换

float f1=(float)5.1;

// 第二种方式:没有类型转换;

folat f2=5.1f;

}

再来看看下面的测试,结果肯定十之八九会在意料之外public static void main(String[] args) {

float a = 12345678.90123456789f;

double b=0.12345678901234567890;

float c=0.12345678901234567890f;

System.out.println(a);

System.out.println(b);

System.out.println(c);

打印结果

a = 1.2345679E7

b = 0.12345678901234568

c = 0.12345679

}

以上就是java中的浮点型数据类型,看完之后是否有所收获呢?如果想了解更多相关内容,欢迎关注亿速云行业资讯,感谢各位的阅读。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值