1、java基本数据类型
int 4 最大值 0x7fffffff 2147483647=2的31次方-1 首位为符号位 最小值-2147483648 0x80000000 补码存储 首位不变 其他位取反后加1
short 2 最大值2^15-1 32767 最小值-2^15 -32768
long 8 最大值2^63-1 最小值-2^63
byte 1 最大值2^7-1 127 最小值-2^7 -128
float 4 在内存中保存的字节格式 SEEE EEEE EMMM MMMM MMMM MMMM MMMM MMMM
S 代表符号位,1是负,0是正
E 偏移127的幂,二进制阶码=(EEEEEEEE)-127。
M 24位的尾数保存在23位中,只存储23位,最高位固定为1。此方法用最较少的位数实现了
较高的有效位数,提高了精度。
double 8 和上面类似,能够精度更高范围更大的数,如Double.MAX_VALUE=1.7976931348623157E308 1.7976931348623157*10^308
char 2
boolean 2
注意:float和double只能用来做科学计算或者是工程计算; 在商业计算中我们要用java.math.BigDecimal。
2、java类型转换
1)基本数据类型转换
Java 语言是一种强类型的语言。强类型的语言有以下几个要求:
-变量或常量必须有类型:要求声明变量或常量时必须声明类型,而且只能在声明以后才能使用。
-赋值时类型必须一致:值的类型必须和变量或常量的类型完全一致。
-运算时类型必须一致:参与运算的数据类型必须一致才能运算。
但是在实际的使用中,经常需要在不同类型的值之间进行操作,这就需要一种新的语法来适应这种需要,这个语法就是数据类型转换。
在数值处理这部分,计算机和现实的逻辑不太一样,对于现实来说,1和 1.0 没有什么区别,但是对于计算机来说,1 是整数类型,而 1.0 是小数类型,其在内存中的存储
方式以及占用的空间都不一样,所以类型转换在计算机内部是必须的。
Java 语言中的数据类型转换有两种:
-自动类型转换:编译器自动完成类型转换,不需要在程序中编写代码。
-强制类型转换:强制编译器进行类型转换,必须在程序中编写代码。
由于基本数据类型中 boolean 类型不是数字型,所以基本数据类型的转换是出了 boolean 类型以外的其它 7 种类型之间的转换。下面来具体介绍两种类型转换的规则、
适用场合以及使用时需要注意的问题。
1>自动数据类型转换
转换规则:从存储范围小的类型到存储范围大的类型。
具体规则为:byte→short(char)→int→long→float→double
在进行运算的时候,整型与浮点型运算会转换成浮点型,长整型与浮点型运算也是转换成浮点型。
2>强制数据类型转换
该类类型转换很可能存在精度的损失,所以必须书写相应的代码,并且能够忍受该种损失时才进行该类型的转换。
具体规则为:double→float→long→int→short(char)→byte
语法格式为:(转换到的类型)需要转换的值
注意:
小数转整数的时候,采用的是去1法,无条件舍去小数部分。
整数(byte ,char ,short ,int ,long)直接的转换规则
A、长变短 直接截取
如 int i=0xffffff01;byte b=(byte)i;System.out.println(b);输出是1,直接截取后八位0x01。
B、短变长 如果是有符号位的,除开char之外的执行符号扩展;
没有符号位的,如char,直接在符号前面补0。
如 (
int
)(
char
)(
byte
)-
1 输出是65535.
第一步:int->byte 0xffffffffffffffffffffffffffffffff 截取后八位 0xffffffff
第二步:byte->char 0xffffffff 带符号 执行符号扩展 负数就在前面补1正数补0 0xffffffffffffffff
第三步:char->int 0xfffffffffffffff char转int 直接补0 0x0000000000000000ffffffffffffffff
最后变成了65535
2)引用数据类型转换
这一部分在面向对象中复习。