详述Java基本数据类型

  • Post author:
  • Post category:java

一、数据类型决定了内存中存储数据的类型及所需内存的大小。 

二、Java的数据类型可分为两大类:

      基本数据类型:byte、short、int、long、double、float、boolean、char 。

      引用数据类型:类、接口、数组、枚举、注解。

以下是Java中数据类型对应的字节数、位数以及取值范围:

 基本数据类型分类详解:

1、整型(int)

      整型是用来定义整数的关键字,四种整型(byte、short、int、long)都有其表示范围。

      Java整形数据类型的有如下4种表示形式:              

      十进制整数,例如12,-127,0。               

      二进制整数,以0b开头,例如0b011 (对应于十进制的3 ) (JDK7.0开始)。              

      八进制整数,以0开头,例如014(对应于十进制的12)。              

      十六进制整数,以0x或0X开头,例如0XF(对应于十进制的15)。

      ( 注意:由于不同整型数据类型在内存中分配的大小不一样,所以我们在开发中到底使用哪种数据类型要慎重思考,这关系到程序的性能,比如人的年龄不会超过200岁,所以选择short比较合适。选择浮点型的时候也应如此。)

2、浮点型(float)

      浮点型是用来定义小数的关键字。

      浮点型数据有如下两种表示方式:              

      十进制形式,例如3.14。              

      科学计数法形式,例如3.14e1。

      注意:float f = 1.3;是错误的,1.3默认是double型的。在对float数据进行赋值时,要在数字的后面添加f(或F),否则Java编译器会认为1.3是一个double类型的数值,而double是64位不能直接赋值给32位的float类型,故:正确赋值方式应为float f1 = 1.3f或float f1 =  (float) 1.3。

3、布尔型(boolean)

      布尔型,又称逻辑类型,只有true和false两个取值,默认初始值为false。这区别与C语言,在C语言标准(C89)没有定义布尔类型,所以C语言判断真假时以0为假,非0为真,例下C程序:

 其中flag=3非零,所以if中条件为真。然而在二进制逻辑中Java规定1为真0为假。

4、字符型(char)

      字符型采用Unicode编码,一个Unicode编码占2个字节(即16位),由于字符型不存在正负之分,所以其表示范围为0至2的16次方-1(0~65535)。

       该种数据类型的变量可以有以下几种赋值方式:  

      (1) 使用英文单引号(’)括起单个字符,例如:    

                   char c1 = ‘a’;    

                   char c2 = ‘中’;//char可以存储一个中文(一个中文也占2个字节);  

      (2)使用英文单引号括起来十六进制字符代码值来表示单个字符,格式为‘\uXXXX’,其中u是约定的前缀,为Unicode的第一个字母,例如:    

                    char c1 =’\u0061′;// 实质代表a字母  

      (3)可以直接使用数字表示单个字符,例如:    

                    char c2 = 97;//表示a字母  

      (4)某些特殊的字符可以采用转义符’\’来表示,以将其后面的字符转变为其它含义,例如:    

                    char c1 = ‘\t’;//制表符    

                    char c2 = ‘\n’;//换行符-New Line    

                    char c3 = ‘\r’;//回车符-Carriage Return

 { Unicode与ASCII的区别 :

1、两者都是一种编码规范;

2、ASCII是专门用来表示英文字符;而Unicode可以表示所有字符,编码范围比ASCII更大(ASCII可表示255个字符,                 即1个字节);

3、Unicode编码表与ASCII编码表前127个字符(即排除了ASCII编码表扩展字符)相同。}

三、基本数据类型转换

1、Java数据类型转换(无论是基本数据类型还是引用类型)分为:      

      自动类型转换      

      强制类型转换

2、将表示范围小的数据类型赋值给表示范围大的数据类型时,Java自动使用隐式类型完成数据类型转换,即:      

      低————————————————————————————————————————–>高      

      byte  ————>  short/char  ————>  int  ————>  long  ————>  float  ————>  double

3、当把级别高的变量赋值给级别低的变量时,必须使用显式类型转换。显示转换格式:(要转换的类型)被转换的值。

2的8次方 = 256 int 类型256二进制补码:0000 0000 0000 0000 0000 0001 0000 0000 强制将256存为byte类型:0000 0000

举例如下:

尝试编写如下java文件:(a、b可以自由赋值,a为小数,b为大于127的数)

进行编译运行,结果出现精度缺失和数据溢出现象: 

 


版权声明:本文为qq_42874854原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。