A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© ok-Prince 中级黑马   /  2014-3-10 07:42  /  1298 人查看  /  8 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 ok-Prince 于 2014-3-10 11:02 编辑
  1. class  Cz
  2. {
  3.         public static void main(String[] args)
  4.         {
  5.                 int x = 5;
  6.                 short y = 5;
  7.                 x = x/2;
  8.                 y = y + 2;
  9.         }
  10. }
复制代码

毕老师讲过,y为short型,y = y + 2会丢失精度,那上面的x = x/2呢?x = 5,那么x/2应该是2.5,是浮点型的才对,那浮点型赋值给int型难道就不会损失精度么?

8 个回复

倒序浏览
浮点型赋值给int型是会损失精度的但是不会报错
y = y+2报错是因为运算过程中short型自动提升为了int,你把大容量的int赋值给了小容量的short
自动转换
自动转换发生在不同数据类型的量混合运算时,由编译系统自动完成。自动转换遵循以下规则:
1.若参与运算量的类型不同,则先转换成同一类型,然后进行运算。
2.转换按数据长度增加的方向进行,以保证精度不降低。如int型和long型运算时,先把int量转成long型后再进行运算。
3.所有的浮点运算都是以双精度进行的,即使仅含float单精度量运算的表达式,也要先转换成double型,再作运算。
4.char型和short型参与运算时,必须先转换成int型。
5.在赋值运算中,赋值号两边量的数据类型不同时, 赋值号右边量的类型将转换为左边量的类型。 如果右边量的数据类型长度左边长时,将丢失一部分数据,这样会降低精度, 丢失的部分按四舍五入向前舍入。
强制类型转换
强制类型转换是通过类型转换运算来实现的。其一般形式为: (类型说明符) (表达式) 其功能是把表达式的运算结果强制转换成类型说明符所表示的类型。例如: (float) a 把a转换为实型(int)(x+y) 把x+y的结果转换为整型在使用。
强制转换时应注意以下问题:
1.类型说明符和表达式都必须加括号(单个变量可以不加括号),如把(int)(x+y)写成(int)x+y则成了把x转换成int型之后再与y相加了。
2.无论是强制转换或是自动转换,都只是为了本次运算的需要而对变量的数据长度进行的临时性转换,而不改变数据说明时对该变量定义的类型。
回复 使用道具 举报
5是int 型,2也是int型,所以相除得到的结果也是int型,而int型相除只取整数,
此时得到的x=x/2=5/2=2;
回复 使用道具 举报
tacyjay在路上 来自手机 中级黑马 2014-3-10 10:13:46
板凳
1楼的很全面,关键就是,数据提升后,小的赋给大的没有问题,大的赋给小的,就提示编译未通过,损失精度了。
回复 使用道具 举报
12560zhang 发表于 2014-3-10 08:00
5是int 型,2也是int型,所以相除得到的结果也是int型,而int型相除只取整数,
此时得到的x=x/2=5/2=2;
...

懂了,谢谢~:handshake
回复 使用道具 举报
焚雨成灰 发表于 2014-3-10 07:57
浮点型赋值给int型是会损失精度的但是不会报错
y = y+2报错是因为运算过程中short型自动提升为了int,你把 ...

很全面,谢谢:handshake
回复 使用道具 举报
tacyjay在路上 发表于 2014-3-10 10:13
1楼的很全面,关键就是,数据提升后,小的赋给大的没有问题,大的赋给小的,就提示编译未通过,损失精度了 ...

嗯,这个我知道,就是有点想不明白既然运算结果已经损失精度了,那为什么java不报错。:handshake
回复 使用道具 举报
x 是整形,2也是整形,所以相除结果也是整形。
建议,看看基础的数据类型
回复 使用道具 举报
  1. class  Cz
  2. {
  3.         public static void main(String[] args)
  4.         {
  5.                 int x = 5;
  6.                 short y = 5;
  7.                 x = x/2;     //这里的“/”不是“÷”而是取整 5/2=2  余1    ”  %“是取余
  8.                 y = y + 2;
  9.         }
  10. }
复制代码
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马