本帖最后由 aA772807986 于 2016-11-12 21:48 编辑
[Java] 纯文本查看 复制代码 package com.lxy.test;
/**
* 1,与运算符用符号“&”表示,其使用规律如下:两个操作数中位都为1,结果才为1,否则结果为0,
* 2,或运算符用符号“|”表示,其运算规律如下:两个位只要有一个为1,那么结果就是1,否则就为0,
* 3,非运算符用符号“~”表示,其运算规律如下:如果位为0,结果是1,如果位为1,结果是0,
* 4,异或运算符是用符号“^”表示的,其运算规律是:两个操作数的位中,相同则结果为0,不同则结果为1
* 5,左移(<<)低位补0:例如num<<1,相当num*2的1次方,以此类推 * 6,右移(>>)高位补0:例如num>>2,相当num*2的2次方,以此类推
* 7,无符号右移(>>>),忽略符号位,空位都以0补齐
*/
public class Test12 {
public static void main(String[] args) {
int a = 128, b = 129;
// String value = Integer.toBinaryString(a);//使用Integer自带的静态方法
System.out.println("a=" + a + ";a的二进制数:" + toBinaryString(a));
System.out.println("b=" + b + ";b的二进制数:" + toBinaryString(b));
System.out.println("a&b=" + (a & b));// 128
System.out.println("a|b=" + (a | b));// 129
System.out.println("~a=" + (~a));// -129
System.out.println("~b=" + (~b));// -130
System.out.println("a^b=" + (a ^ b));// 1
}
// 求一个int类型的二进制
public static String toBinaryString(int a) {
StringBuffer buffer = new StringBuffer();
while (a > 0) {
buffer.append(a % 2);
a = a / 2;
}
return buffer.reverse().toString();
}
// 将一个二进制转换成int类型
public static int toInt(String val) {
int value = 0;
for (int i = val.length() - 1; i >= 0; i--) {
// Math.pow(double a, double b);
value += Integer.parseInt("" + val.charAt(i)) << (val.length() - 1 - i);// 直接求2的i次方
}
return value;
}
}
|