您的位置:首页 > 编程语言 > Java开发

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所述,编译器会自动溢出高位而不报错,所以我们看到结果是一个负数。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: