java细节之byte和int运算区别
2014-02-08 11:28
302 查看
<转载请申明出处,多谢合作>
博主不废话,直接给例子道出现象了撒:
public class Test{
public static void main(String[]args){
byte b=0;
b=1+2;
//1.正确
byte b1=1;
byte b2=2;
b=b1+b2:
//2.出错了
int i=0;
i=1+2;
//3.正确
int i1=1;
int i2=2;
i=i1+i2;
//4.正确
i=Integer.MAX_VALUE+1;
//5.正确
}
}
上面的代码可能会让一些新手朋友们困惑了,这是为什么呢,为什么同样的1+2有的行,有的就不行呢?这就涉及到对数值类型的一些认识了,下面分别对上面5点注释进行说明:
1.b=1+2,相当于b=3,3是个常量,编译器会判断3是否在byte范围类(-128~127),在的话,编译器会将3这个整型保留最后一个字节赋值给b,所以正确
2.b=b1+b2,由于b1+b2之后还是一个变量,编译器会无法判断这个结果是否在byte范围类,所以会报出可能超过范围的错误
3.i=1+2,毫无疑问
4.i=i1+i2这个时候有些朋友可能就疑惑了,为什么2是错的,4就对了这个疑问吧,这个就和int是默认类型有关系了,当编译器碰到默认类型运算的时候会自动的进行溢出这个操作,所以编译器会忽视掉像2这样的错误
5.i=Integer.MAX_VALUE+1,右边明显超过了整型最大值,但是如4所述,编译器会自动溢出高位而不报错,所以我们看到结果是一个负数。
博主不废话,直接给例子道出现象了撒:
public class Test{
public static void main(String[]args){
byte b=0;
b=1+2;
//1.正确
byte b1=1;
byte b2=2;
b=b1+b2:
//2.出错了
int i=0;
i=1+2;
//3.正确
int i1=1;
int i2=2;
i=i1+i2;
//4.正确
i=Integer.MAX_VALUE+1;
//5.正确
}
}
上面的代码可能会让一些新手朋友们困惑了,这是为什么呢,为什么同样的1+2有的行,有的就不行呢?这就涉及到对数值类型的一些认识了,下面分别对上面5点注释进行说明:
1.b=1+2,相当于b=3,3是个常量,编译器会判断3是否在byte范围类(-128~127),在的话,编译器会将3这个整型保留最后一个字节赋值给b,所以正确
2.b=b1+b2,由于b1+b2之后还是一个变量,编译器会无法判断这个结果是否在byte范围类,所以会报出可能超过范围的错误
3.i=1+2,毫无疑问
4.i=i1+i2这个时候有些朋友可能就疑惑了,为什么2是错的,4就对了这个疑问吧,这个就和int是默认类型有关系了,当编译器碰到默认类型运算的时候会自动的进行溢出这个操作,所以编译器会忽视掉像2这样的错误
5.i=Integer.MAX_VALUE+1,右边明显超过了整型最大值,但是如4所述,编译器会自动溢出高位而不报错,所以我们看到结果是一个负数。
相关文章推荐
- java 中byte转int为何要与0xff进行与运算 c 和java右移运算区别
- java中byte转换int时为何与0xff进行与运算
- Java中byte转换int时与0xff进行与运算的原因
- 类型转换问题(java会把byte,short和char的运算操作转换为int类型即低精度自动向高精度转换)
- java中byte转换int时为何与0xff进行与运算
- java中byte转换int时为何与0xff进行与运算
- Java中byte转换int时与0xff进行与运算的原因
- [转]java中byte转换int时为何与0xff进行与运算
- java中byte转换int时为何与0xff进行与运算
- java中byte转换int时为何与0xff进行按位与运算
- 【转载】java中byte转换int时为何与0xff进行与运算
- java中byte转换int时为何与0xff进行与运算
- java中byte转换int时为何与0xff进行与运算
- [转]java中byte转换int时为何与0xff进行与运算
- java对byte,short,char,int,long运算时自动类型转化情况说明
- java中byte转换int时为何与0xff进行与运算
- java中byte转换int时为何与0xff进行与运算
- java中byte转换int时为何与0xff进行与运算
- [转]java中byte转换int时为何与0xff进行与运算
- java中byte转换int时为何与0xff进行与运算