精度损失以及不超范围可以直接赋值byte和short

/*
java中有一个语法规则:
当这个整数型字面量没有超出byte的取值范围,那么这个
整数型字面量可以直接赋值给byte类型的变量。

这种语法机制是为了方便写代码,而存在的。
*/
public class 精度损失以及不超范围可以直接赋值byte和short
{
  public static void main(String[] args)
  {
    // 分析:以下代码编译可以通过吗?
    // 300 被默认当做int类型
    // b变量是byte类型
    // 大容量转换成小容量,要想编译通过,必须使用强制类型转换符。
    // byte b = 300;

    // 要想让以上的程序编译通过,必须加强制类型转换符
    // 虽然编译通过了,但是可能精度损失。
    // 300这个int类型对应的二进制:00000000 00000000 00000001 00101100
    // byte占用1个字节,砍掉前3个字节,结果是:00101100 (44)
    byte b = (byte)300;
    System.out.println(b); // 44

    // 这个编译能通过吗?
    // 1是int类型,默认被当做int类型来看。
    // x是byte类型,1个字节,大容量无法直接转换成小容量;
    // 按说是编译报错的;
    byte x = 1;
    byte y = 127;
    //byte z = 128;//错误不兼容的类型:从int转换到byte可能会有损失

    // 当整数型字面量没有chaocshort类型取值范围的时候,该字面量可以直接赋值给short。
    // 类型的变量
    short s = 1;
    short s1 = 32767;
    // 错误:不兼容的类型:从int转换到short可能会有损失
    //short s2 = 32768;
    System.out.println(s);
  }
}

精度损失以及不超范围可以直接赋值byte和short

上一篇:maven


下一篇:浅析如何选择picture标签和img标签、如何使用 srcset 和 sizes 属性进行分辨率切换、如何使用picture标签的source和media在不同设备显示不同图像