java 浮点数计算问题
intm=(e==0)?((bits&0x7fffff)<<1):((bits&0x7fffff)|0x800000)解释一下这句话的意思,主要是后面这个((bits&0...
int m = (e==0)?((bits & 0x7fffff) << 1):
((bits & 0x7fffff) | 0x800000)
解释一下这句话的意思,主要是后面这个((bits & 0x7fffff) | 0x800000)没看懂... 展开
((bits & 0x7fffff) | 0x800000)
解释一下这句话的意思,主要是后面这个((bits & 0x7fffff) | 0x800000)没看懂... 展开
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位清零后,再左移一位。
至于问号,就不用解释了吧?
&叫做“按位与”,其规则是: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位清零后,再左移一位。
至于问号,就不用解释了吧?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询