Java 基础 之 位运算
【摘要】 http://www.verejava.com/?id=16992602784016public class Operation5 { public static void main(String[] args) { //位运算 /* 包括: 与 &, 或 |, 取反 ~, 异或 ^ 带符号左移<<, 带符号右移 >>, 无符号右移 >>> 1. & 就是二进制位...
http://www.verejava.com/?id=16992602784016
public class Operation5 {
public static void main(String[] args) { //位运算
/*
包括:
与 &, 或 |, 取反 ~, 异或 ^
带符号左移<<, 带符号右移 >>, 无符号右移 >>>
1. & 就是二进制位如果都是1则为1,否则为0
2. | 就是二进制位如果都是0则为0,否则为1
3. ~ 就是二进制位如果是0取反变成1,否则如果是1取反变成0;
4. ^ 就是运算两边二进制位两边同时相等时为0,否则为1
5. <<就是将二进制位逐位向左移动n位,后面补n个0,相当于乘2;
6. >>就是将二进制位逐位向右移动n位,前面补n个符号位,向当于除2;
6. >>>就是将二进制位逐位向右移动n位,前面补n个0
*/
byte a = 1; //二进制 00000001
byte b = 8; //二进制 00001000
byte c = 127; //二进制 01111111
byte d = -127;//二进制 10000001
System.out.println(a & b); //结果 00000000
System.out.println(a | b); //结果 00001001 2^3+2^0=9
System.out.println(~a); //结果 11111110补码 转换为原码=10000001=-1-1=-2
System.out.println(a ^ b); //结果 00001001 =9;
System.out.println(a << 1); //结果 00000010 2^1=2
System.out.println(c << 1); //结果 11111110 =254
System.out.println(a >> 1); //结果 00000000 =0
System.out.println(c >> 1); //结果 00111111 =63
System.out.println(d >> 1); //结果 11000000补码 原码=10111111=-63-1=-64
System.out.println(d >>> 1);//结果 01000000原码
/*
注意:
1.计算机存储时 二进制第一位是表示符号位 1 代表负数, 0代表正数
2.计算机存储时以补码的方式存储的, 正数的补码跟原码一样,负数的补码是去掉第一位符号位取反然计算结果后 再 + 1 得到的.
3. 那补码转换成原码就反过来 去掉第一位取反计算结果后 再-1.
4. System.out.println 没有 System.out.println(byte b)方法,计算机先自动将byte转化成 int 然后在移动
*/
}
}
【声明】本内容来自华为云开发者社区博主,不代表华为云及华为云开发者社区的观点和立场。转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息,否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)