Java 基础知识-(面试题之变量相加、常量相加)

b3错误:
1、byte与byte(或short,char,int)进行运算的时候回提升为int。
2、b1和b2是两个变量,变量存储的值是变化的,在编译的时候无法判断里面具体的值,相加有可能会超出byte的取值范围。

b4正确:

Java编译器有常量优化机制,直接判断(3+4)的结果,结果为常量,范围在-128~127之间。


注意:

1、进行混合运算时,byte、short、char不会相互转换,都会隐式转换为int类型。

2、其他类型混合运算的时候,小的数据类型提升为大的。

byte、short、char --> int(4字节) --> long(8字节) --> float(4字节) --> double(8字节)

此时有人会疑问,为什么long(8字节)会隐式转换为float(4字节)呢?分解如下:


f赋予l,编译器报错,可能损失精度,必须强制类型转换。


float占4个字节,IEEE 754做了以下规定:

32个二进制位

1位代表符号位

8位指数位(00000000 - 11111111),即 0 ~ 255,0代表0,255代表无穷大

余:1 ~ 254,(又规定,指数需要-127),指数范围最终为 - 126 ~ 127。

23位代表尾数位(小数位)

long最大值:2^63-1

!所以!float的范围比long大!

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值