java 浮点数计算问题

2025-04-27 23:39:30
推荐回答(1个)
回答1:

这是位运算,一般在硬件控制方面用的多,光看表达式的话无法知道其具体的意义是什么。得结合实际才行。

&叫做“按位与”,其规则是:0&0=0 1&0=0 0&1=0 1&1=1
“|”叫做“按位或”,运算规则是:0|0=0 1|0=1 0|1=1 1|1=1

0x7fffff用32位二进制表示就是 0000 0000 0111 1111 1111 1111 1111 1111
根据按位与的运算法则就是把bits的高9位清零。
0x800000用32位二进制表示是 0000 0000 1000 0000 0000 0000 0000 0000
根据按位或的运算法则就是把第24位置1。
那么综合来看,((bits & 0x7fffff)|0x800000)的意思就是先把bits的高9位清零,然后再把第24位置1。

关于前半部分,“<<”叫做左移,就是把所有二进制位向左移动若干位。和上面同理,就是先把bits的高9位清零后,再左移一位。

至于问号,就不用解释了吧?