java中的按位逻辑运算符

时间:2015-08-30 13:24:04

标签: java reverse bitwise-operators

我试图扭转局面,但有些事情出错了。

String binary[]={
        "0000","0001","0010","0011","0100","0101",
        "0110","0111","1000","1001","1010","1100",
        "1101","1110","1111"
    };
    int a=3;
    int b=6;
    int c=a|b;
    int d=a&b;
    int e=a^b;
    int f=(~a &b) | (a&~b);
    int g= ~a & 0x0f;

    System.out.println(" a="+binary[a]);
    System.out.println(" b="+binary[b]);
    System.out.println(" a|b="+binary[c]);
    System.out.println(" a&b="+binary[d]);
    System.out.println(" a^b="+binary[e]);
    System.out.println(" ~a&b|a&~b="+binary[f]);
    System.out.println(" ~a="+binary[g]);**

输出是:

 a=0011
 b=0110
 a|b=0111
 a&b=0010
 a^b=0101
 ~a&b|a&~b=0101
 ~a=1101

最后一个是错的。反过来必须是1100.我做错了什么?

2 个答案:

答案 0 :(得分:1)

String binary[]={
    "0000","0001","0010","0011",
    "0100","0101","0110","0111",
    "1000","1001","1010","1011",
    "1100","1101","1110","1111"
};

小学:你错过了一个二进制值。以更明显的模式排序会有所帮助。

答案 1 :(得分:0)

你的二进制字符串是不正确的,位移是,这是正确的二进制字符串数组:

String binary[]={
            "0000","0001","0010","0011","0100","0101",
            "0110","0111","1000","1001","1010","1011",
            "1100","1101","1110", "1111"
    };

使用您的代码,这是输出:

a=0011
b=0110
a|b=0111
a&b=0010
a^b=0101
~a&b|a&~b=0101
~a=1100