数据类型决定了内存中存储数据的类型及所需内存的大小。
Java的数据类型可分为两大类:
基本数据类型:byte、short、int、long、double、float、boolean、char。
引用数据类型:类、接口、数组、枚举、注解。
而byte只用1个字节,short用2个字节,int用4个字节,long用8个字节,double用8个字节,float用4个字节,char用2个字节,boolean只用1位也就是1比特位。
byte:8位,最大存储数据量是255,存放的数据范围是-128~127之间。
short:16位,最大存储量是65536,数据范围是-32768~32767之间。
int:32位,最大数据存储容量是2的32次方减1,数据范围是负的2的31次方到正的2的31次方减1。
long:64位,最大数据存储容量是2的64次方减1,数据范围为负的2的63次方到正的2的63次方减1。
float:32位,数据范围在3.4e-45~1.4e38,直接赋值时必须在数字后加上f或F。
double:64位,数据范围在4.9e-324~1.8e308,赋值时可以加d或D也可以不加。
boolean:1位,只有true和false两个取值。
char:16位,存储Unicode码,用单引号赋值。而且char可以用来保存汉字。
Java整形数据类型的有如下4种表示形式:
十进制整数,例如22,34、二进制整数,以0b开头,例如0b011就是十进制的3、 八进制整数,以0开头,例如014就是十进制的12、 十六进制整数,以0x或0X开头,例如0XF对应于十进制的15。
长整型:长整型必须以L作结尾,例如15L。
浮点型数据有如下两种表示方式:十进制形式,例如3.14,科学计数法形式,例如3.14e1。
布尔型,又称逻辑类型,只有true和false两个取值,默认初始值为false。Java在二进制逻辑中规定1为真0为假。(在C语言中规定非0为真0为假)
字符型,可用以下方法赋值
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
以上为Java的基本数据类型介绍。下面则是涉及到基本数据类型之间的转换。
分为自动型转换和强制型转换。
自动型转换是将表示范围小的数据类型赋值给表示范围大的数据类型时Java自动使用隐式类型完成数据类型转换,即byte 到 short/char 到 int 到 long 到 float 到 double。
例如double a=100,则此时是把int赋值为double,a=100.0
而强制型转换则是把级别高的变量赋值给级别低的变量时,必须使用显式类型转换。显示转换格式:(要转换的类型)被转换的值。
例如int x=(int)88.88,此时x=88,此时明显发现精度发生了改变,除此之外还有另一种情况比如byte a=(byte)256,此时a会显示为0,因为byte最高才127,导致数据溢出使a为0。
在此扩展一下,正数中补码=源码,负数中:补码=反码(符号位不变,其它全部由0变1或由1变0)+1,而当把高的变量赋值给级别低的变量时,计算机会从右边取,也就是十六位只取右边八位,正因为这使得溢出的出现。
注意: float f =9.8;是错误的,9.8默认是double型的。在对float数据进行赋值时,要在数字的后面添加f(或F),否则Java编译器会认为9.8是一个double类型的数值,而double不能直接赋值给float类型,
正确赋值方式应为float f1 = 9.8f。