Java中为什么byte b=3;可以?3不是默认为int类型了吗?
展开全部
因为=是赋值操作符
所以byte b=3;系统会去检测3在不在byte的范围内,也就是-128-127之间
在的话就没有问题
你可以尝试
byte b=128;
如果你用Eclipse就会提示你类型不匹配,不能从int转到byte
当然,还有就下面的情况也会出现问题
byte b=3;
b=b+3;
这句就会出现问题,因为这里是涉及到算术操作符+
byte类型的和int类型的相加,自然就会将byte类型转为int类型,计算后的结果就为int类型
此时,int类型的值赋值给byte类型的b就会提示出错
但是!!!!
如果b=b+3;改成
b+=3;就不会出错!
因为+=也是赋值运算符,没有涉及到类型转换的问题
所以byte b=3;系统会去检测3在不在byte的范围内,也就是-128-127之间
在的话就没有问题
你可以尝试
byte b=128;
如果你用Eclipse就会提示你类型不匹配,不能从int转到byte
当然,还有就下面的情况也会出现问题
byte b=3;
b=b+3;
这句就会出现问题,因为这里是涉及到算术操作符+
byte类型的和int类型的相加,自然就会将byte类型转为int类型,计算后的结果就为int类型
此时,int类型的值赋值给byte类型的b就会提示出错
但是!!!!
如果b=b+3;改成
b+=3;就不会出错!
因为+=也是赋值运算符,没有涉及到类型转换的问题
2020-03-04
展开全部
byte:8位,最大存储数据量是255,存放的数据范围是-128~127之间。
short:16位,最大数据存储量是65536,数据范围是-32768~32767之间。
int:32位,最大数据存储容量是2的32次方减1,数据范围是负的2的31次方到正的2的31次方减1。
long:64位,最大数据存储容量是2的64次方减1,数据范围为负的2的63次方到正的2的63次方减1。
float:32位,数据范围在3.4e-45~1.4e38,直接赋值时必须在数字后加上f或F。
double:64位,数据范围在4.9e-324~1.8e308,赋值时可以加d或D也可以不加。
boolean:只有true和false两个取值。
char:16位,存储Unicode码,用单引号赋值。
short:16位,最大数据存储量是65536,数据范围是-32768~32767之间。
int:32位,最大数据存储容量是2的32次方减1,数据范围是负的2的31次方到正的2的31次方减1。
long:64位,最大数据存储容量是2的64次方减1,数据范围为负的2的63次方到正的2的63次方减1。
float:32位,数据范围在3.4e-45~1.4e38,直接赋值时必须在数字后加上f或F。
double:64位,数据范围在4.9e-324~1.8e308,赋值时可以加d或D也可以不加。
boolean:只有true和false两个取值。
char:16位,存储Unicode码,用单引号赋值。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询