Java数值类型之间转换

Java之间的数值转换如图所示,实心箭头代表无数据丢失,虚线箭头代表可能丢失

例如:123456789是一个大的整数,包含的位数比float类型能够表达的位数多,但这个数转换为float类型时,将会得到同样大小的结果,但却失去了一定的精度。

int n = 123456789;
float f =n;        //f is 1.23456792E8

当转换前后两个数进行二元操作时(例如n+f,n为整数,f为浮点数),则先将两个操作数转换为同一个类型,再进行计算。

转换规则:

--如果两个操作数中有一个是double类型,另一个操作数就会转换为double类型。

--否则,如果其中一个操作数是float类型时,另一个操作数将会转换为float类型。

--否则,如果其中一个操作数是long类型时,另一个操作数将会转换为long类型。

--否则,两个操作数都将会被转换为int类型。

 

强制转换类型

在Java中允许进行像int转换为double类型或者double转换为int,但有可能丢失一些信息。如像强制转换类型,则需要通过强制类型转换(cast)实现。强制类型转换的语法格式是在圆括号中给出想要转换的目标类型,后面紧跟待转换的变量名

例如

double x = 9.887;
int nx = (int)x;

变量nx的值为9。强制类型转换通过截断小数将浮点值转换为整型。

如果想将浮点数进行舍入运算,以得到最接近的整数,就需要使用Math.round方法:

double x = 9.887;
int nx = (int)Math.round(x);

现在变量nx的值为10.调用round的时候仍然需要使用强制类型转换(int)。原因为:round方法返回结果为long类型,由于存在信息丢失可能性,所以只有使用显式的强制类型转换才能够将long类型转换为int类型。

转载于:https://www.cnblogs.com/circleyuan/p/10350193.html

自动类型转换,也称隐式类型转换,是指不需要书写代码,由系统自动完成的类型转换。由于实际开发中这样的类型转换很多,所以Java语言在设计时,没有为该操作设计语法,而是由JVM自动完成。 转换规则 从存储范围小的类型到存储范围大的类型。 具体规则为: 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 注意问题 在整数之间进行类型转换时,数值不发生改变,而,特将整数类型别是比较大的整数类型转换成小数类型时,由于存储方式不同,有可能存在数据精度的损失。 强制类型转换,也称显式类型转换,是指必须书写代码才能完成的类型转换。该类类型转换很可能存在精度的损失,所以必须书写相应的代码,并且能够忍受该种损失时才进行该类型转换转换规则 从存储范围大的类型到存储范围小的类型。 具体规则为: 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位(也就是最后一个字节)的值。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值