java 中定义byte b = 10;byte c = 5;b = b + c;为什么会出现编译错误呢?
4个回答
展开全部
这个问题所涉及到的问题是“自动类型提升”:
在java中,对char, byte和short类型的字符串进行数学算法操作,比如+,-,>>位移等操作,都会引发自动类型提升,运算结果将是int类型,要将int的值赋给byte就会出现编译错误,所以就必须进行类型强制转换。语句如下:
byte b = 10;byte c = 5;b = (byte) (b + c);
关于类型的自动提升,java定义若干适用于表达式的类型提升规则:
第一,所有的byte型、short型和char型的值将被提升到int型;
第二,如果一个操作数是long型,计算结果就是long型;
第三,如果一个操作数是float型,计算结果就是float型;
第四,如果一个操作数是double型,计算结果就是double型。
展开全部
b+c 默认的类型的int类型 你需要byte 需要强制转换 因为int到byte是大转小 需要强制转换
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
运算规则,两个byte类型相加和默认为int,所以要转换一下格式就好了,如b = (byte)(b + c)
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
byte b = 10;byte c = 5;b = (byte) (b + c);
这样就好了,这需要强制类型转换
这样就好了,这需要强制类型转换
追问
我知道这样就没有问题了,不强制转换为什么就会编译错误呢?
我定义的不都是byte的类型的吗
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询