百木园-与人分享,
就是让自己快乐。

Java中的基本数据类型

Java中的8大基本数据类型

基本数据类型的种类和大小、数据在计算机中的存储形式(二进制补码)、强制类型转换在二进制中的原理、字面值的赋值规则和多种数据类型混合计算转型规则。

 

1.byte:  字节型  1个字节  8位   [-128,127]

2.short::  短整型  2个字节  16位  [-2^15,2^15-1]   

3.int:    整形   4个字节  32位  [-2^31,2^31-1]

4.long:   长整形  8个字节  64位  

5.float:    单精度  4个字节  32位

6.double:  双进度  8个字节  64位

7.boolean:  布尔型  1个字节  8位 

8.char:    字符型  2个字节  16位

注意:

1.在java语言中整数型字面值默认当做int类型,如果想让整数型字面值被当做long类型,需要在字面值后面添加l/L,一般多用L。

  

 

  报错的原因是 自动将字面值当做int类型来处理,而2147483648已经超出了int的范围,所以需要将它标识为其他的能容纳它的类型。

  

 

2.强制转换的原理 

  以long 类型强制转换为int类型为例,假设有一个long类型的数据是 00000000  00000000  00000000  00000000  00000000  00000000  00000000  01100100,

  将它强转为int,就是直接将long类型的前四个字节砍掉,只拿后面的四个字节。00000000  00000000  00000000  01100100。

  所以,强制类型转换需谨慎,有可能会丢失精度。

  

  上例:解剖  (计算机存储数据是以二进制补码的形式存储  正数的补码和源码相同,负数的补码  是负数的绝对值对应的二进制码 对位取反再+1)

  2147483648L 的二进制是  00000000  00000000  00000000  00000000  10000000  00000000  00000000  00000000

  强制类型转换后得到的是  10000000  00000000  00000000  00000000  (砍掉前4个字节)

  也就是说  10000000  00000000  00000000  00000000  这是原数据的补码形式  补码求源码

  先减1     01111111    11111111   11111111    11111111

  对位取反  10000000  00000000  00000000  00000000 

  所以源码是 10000000  00000000  00000000  00000000  2147483648

  而补码的符号位是1(首位),则表示该数据是负数,所以原数据是  -2147483648

  2147483648L是long类型,8个字节,符号位是0,所以对于long类型来说2147483648L是正数

  

 

   按道理说整形字面值赋值给byte,大专小需要强制类型转换,但是编译通过,而128编译报错,说明底层字面值只要在byte范围内是不需要认为强制类型转换的,此时要纠正错误就需要强制类型转换。

  

   

  具体还原过程以及计算结果

  

 

  char类型尝试

    常见的一些字符的ASCII码 A-->65,a-->97,数字0-->48(其他数字或字符都是依次递增)

  

  double和float

    带小数的值默认是double 类型,double类型的字面值赋值给float类型变量,大转小需要强制类型转换,所以编译报错

 

    解决办法

      1.强制类型转换为float

      

      2.将字面值标识为float类型

       

3.八种基本数据类型之间的转换规则

  1、八种基本数据类型除了boolean外,其他的都能相互转换。

  2、小容量可以自动向大容量转换,即自动类型转换。容量大小如下

    byte<<short(char)<<int<<long<<float<<double

    

 

    注意:

      1、不管浮点型占几个字节,其容量都比整形大

      2、char和short表示的种类不同,但是char可以取到更大的正整数

  3、强制类型转换慎用,因为有可能会丢失精度

  4、当一个整数字面值没有超过byte,short,char类型的取值范围时,可以直接复制给byte,short,char类型,此时的转换机制底层帮我们完成了,目的是方便程序员开发

  5、byte,short、char运算时,先转换成int后,再参与运算。

  6、多种数据类型混合运算时,先转换成参与运算中最大的数据类型后,再进行计算。

 

      

 


来源:https://www.cnblogs.com/ashes001/p/16089399.html
本站部分图文来源于网络,如有侵权请联系删除。

未经允许不得转载:百木园 » Java中的基本数据类型

相关推荐

  • 暂无文章