繁体   English   中英

有人可以向我解释这个按位程序吗?

[英]Can someone please explain this bitwise program to me?

public class UpCase {
    public static void main(String[] args) {
        int t;
        byte val;
        val = 123;
        for (t = 128; t > 0; t = t / 2) {
            System.out.println(t);
            if ((val & t) != 0) System.out.println(" 1");
            else System.out.println(" 0");
        }
    }
}

特别是,我不确定为什么我们使用val=123 我知道这个程序会以二进制形式打印出 123 但为什么会这样呢? 这是如何运作的? 但是,我确实理解&运算符的原理以及如何打开和关闭位,但我不确定它在此特定示例中的工作原理?

该程序将通过与 2 的每个幂进行比较,将val数字的二进制数字从 MSB 打印到 LSB:

123 : 01111011 &
128 : 10000000 = 
      00000000 

      00000000 != 0 => false, print 0

123 : 01111011 &
 64 : 01000000 = 
      01000000 

      01000000 != 0 =>  true, print 1

123 : 01111011 &
 32 : 00100000 = 
      00100000 

      00100000 != 0 =>  true, print 1

// repeat for 2^4-2^1... 

123 : 01111011 &
  1 : 00000001 = 
      00000001 

      00000001 != 0 =>  true, print 1

很简单:

它只是使用按位运算符 & 检查值(在本例中为 123)。 其结果为 1 或 0,此过程对下一个值 0.5t 重复,直到 t=0,产生此值 123 的二进制字符串。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM