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

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 郭强 中级黑马   /  2013-4-13 01:27  /  1507 人查看  /  3 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 郭强 于 2013-4-13 14:19 编辑
  1. class OperateDemo2
  2. {
  3.         public static void main(String[] args)
  4.         {
  5.                 byte b = 1;
  6.                 byte b0 = 127;
  7.                 b += b0;//可以运行,值为-128;
  8.                 b = b+b0;//可能损失精度;

  9.                 int i = 1;
  10.                 int i0 = Integer.MAX_VALUE;
  11.                 i = i+i0;
  12.                 i += i0;
  13.                 System.out.println(i);

  14.                 short s = 1;
  15.                 short s1 = 32767;
  16.                 s += s1;//值为-32768
  17.                 s = s+s1;//可能损失精度
  18.                 System.out.println(s);
  19.         }
  20. 对于byte,short,一个损失精度,一个溢出,而对于int,long,float,double则不会出现精度丢失的状况,为什么?
  21. }
复制代码

评分

参与人数 1技术分 +1 收起 理由
黄玉昆 + 1

查看全部评分

3 个回复

倒序浏览
byte 占1个字节
short 占2个字节
int 占4个字节
long 占8个字节 其后加L或l标识
double 占8个字节
1个字节对应一个8位的范围:         负2^7 ~正 2^7-1          以此类推、
2个字节对应两个8位的范围: 负2^15 ~正 2^15-1
超出了这个范围就会出错、也就是损失精度

评分

参与人数 1技术分 +1 收起 理由
黄玉昆 + 1

查看全部评分

回复 使用道具 举报

  1. class OperateDemo2
  2. {
  3.         public static void main(String[] args)
  4.         {
  5.                 byte b = 1;
  6.                 byte b0 = 127;
  7.                 b += b0;//可以运行,值为-128;
  8.                 b = b+b0;//可能损失精度;

  9.                 int i = 1;
  10.                 int i0 = Integer.MAX_VALUE;
  11.                 i = i+i0;
  12.                 i += i0;
  13.                 System.out.println(i);

  14.                 short s = 1;
  15.                 short s1 = 32767;
  16.                 s += s1;//值为-32768
  17.                 s = s+s1;//可能损失精度
  18.                 System.out.println(s);
  19.         }

  20. }
复制代码
对于byte,short,一个损失精度,一个溢出,而对于int,long,float,double则不会出现精度丢失的状况,为什么?

byte b = 1,这个1是默认int类型的,而byte和short类型的精度都小于int,那么b = b + b0、s = s+s1自然不会编译通过,需要强制转换(byte)。

Java 语言规范中讲到,复合赋值 E1 op= E2 等价于简单赋值E1 =(T)((E1)op(E2)),其中T 是E1 的类型。所以你例子中的 b += b0;  等价于 b = (byte)(b + b2);能编译通过,只是隐性转换类型。


int,long,float,double精度大于等于默认赋值时的int类型,自然不会强制要求类型转换

评分

参与人数 1技术分 +1 收起 理由
黄玉昆 + 1

查看全部评分

回复 使用道具 举报
请不要这样一连串的发帖,严重会被当做刷帖处理。
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马