码迷,mamicode.com
首页 > 其他好文 > 详细

数据类型及转换

时间:2018-10-08 00:52:35      阅读:220      评论:0      收藏:0      [点我收藏+]

标签:image   数值转换   1.0   out   []   http   alt   布尔   最小   

数据类型:内置、引用;

八种基本类型:6+1+1:6种数字类型,1种字符型,1种布尔型

1>byte   8位1字节,-128~127,

2>int   32位4字节 ,最小值是 -2,147,483,648(-2^31),最大值是 2,147,483,647(2^31 - 1)

3>Long  64位8字节,最小值是 -9,223,372,036,854,775,808(-2^63), 最大值是 9,223,372,036,854,775,807(2^63 -1)

4>float  单精度,32位

5>double  双精度 64位

6>short    16 位,最小值是 -32768(-2^15),最大值是 32767(2^15 - 1)

7>char  16 位 (Unicode编码) 最小值是 \u0000(即为0);  最大值是 \uffff(即为65,535);

结论:

1.整形到浮点型的数据类型转换会有精度损失

2.byte short int long float double 可以直接的相互转化(强转)

 

public class TestDouble {

    public static void main(String args[]) {
        System.out.println("0.05 + 0.01 = " + (0.05 + 0.01));
        System.out.println("1.0 - 0.42 = " + (1.0 - 0.42));
        System.out.println("4.015 * 100 = " + (4.015 * 100));
        System.out.println("123.3 / 100 = " + (123.3 / 100));
    }
}

结果却是:

技术分享图片

原因:

double型的数值在相加减的时候,会将数值转换成二进制的数值如10001.10010110011这种表示发再做相加减,,但是在转换成二进制代码表示的时候,存储小数部分的位数会有不够的现象,即无限循环小数,这就是造成微差距的主要原因。

数据类型及转换

标签:image   数值转换   1.0   out   []   http   alt   布尔   最小   

原文地址:https://www.cnblogs.com/KYin/p/9752102.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!