标题: 数据类型转换概念 [打印本页] 作者: 付旭 时间: 2011-12-14 22:14 标题: 数据类型转换概念 讨厌一些死记硬背的概念 贴出来 供自己加深记忆 作者: 付旭 时间: 2011-12-14 22:15
自动类型转换
自动类型转换,也称隐式类型转换,是指不需要书写代码,由系统自动完成的类型转换。由于实际开发中这样的类型转换很多,所以Java语言在设计时,没有为该操作设计语法,而是由JVM自动完成。
l 转换规则
从存储范围小的类型到存储范围大的类型。
具体规则为:
byte→short(char)→int→long→float→double
也就是说byte类型的变量可以自动转换为short类型,示例代码:
byte b = 10;
short sh = b;
这里在赋值时,JVM首先将b的值转换为short类型,然后再赋值给sh。
在类型转换时可以跳跃。示例代码:
byte b1 = 100;
int n = b1;
l 注意问题
在整数之间进行类型转换时,数值不发生改变,而将整数类型,特别是比较大的整数类型转换成小数类型时,由于存储方式不同,有可能存在数据精度的损失。作者: 付旭 时间: 2011-12-14 22:15
强制类型转换
强制类型转换,也称显式类型转换,是指必须书写代码才能完成的类型转换。该类类型转换很可能存在精度的损失,所以必须书写相应的代码,并且能够忍受该种损失时才进行该类型的转换。
l 转换规则
从存储范围大的类型到存储范围小的类型。
具体规则为:
double→float→long→int→short(char)→byte
语法格式为:
(转换到的类型)需要转换的值
示例代码:
double d = 3.10;
int n = (int)d;
这里将double类型的变量d强制转换成int类型,然后赋值给变量n。需要说明的是小数强制转换为整数,采用的是“去1法”,也就是无条件的舍弃小数点的所有数字,则以上转换出的结果是3。整数强制转换为整数时取数字的低位,例如int类型的变量转换为byte类型时,则只去int类型的低8位(也就是最后一个字节)的值。
示例代码:
int n = 123;
byte b = (byte)n;
int m = 1234;
byte b1 = (byte)m;
则b的值还是123,而b1的值为-46。b1的计算方法如下:m的值转换为二进制是10011010010,取该数字低8位的值作为b1的值,则b1的二进制值是11010010,按照机器数的规定,最高位是符号位,1代表负数,在计算机中负数存储的是补码,则该负数的原码是10101110,该值就是十进制的-46。
l 注意问题
强制类型转换通常都会存储精度的损失,所以使用时需要谨慎作者: 付旭 时间: 2011-12-14 22:16
关于强制转换
之所以需要强制转换是为了防止程序员在不知情的情况下错把A类型的数据当成B类型数据。
程序员使用强制转换,是为了告诉编译器,“我知道我正在把A类型转成B类型,我肯定这样做在运行时不会不错,你就让我编译通过吧!”
强制转换实际上没有破坏被转换的原始数据。可以说强制转型是读操作,不是写操作
例如:
double pi=3.14
int a=(int)pi;
经过这样运算后,内存中的那个pi并没有被改动,只是取出了它的整数部分给了变量a。
子类型引用 要 引用父类型 对象,需要进行强制转换
比如说,Human是父类,Man是子类(因为男人是人)
现在我定义一个对象
Human 楼上的=new Human();//我定义了一个人
我再定义一个“男人” 类型的引用.
Man m;
我要让这个引用指向"楼上的"这个对象,就必须使用强制转型,因为这是一个有可能出错的过程(楼上的有可能是个女人),不强制转型的话,编译器为了降低程序错误,直接不让通过编译!