java中的移位运算符:<<,>>,>>>
2015-08-21 21:22
543 查看
java中有三种移位运算符
<< : 左移运算符,num << 1,相当于num乘以2(2的一次幂),将二进制数向左移,右边补零。
>> : 右移运算符,num >> 1,相当于num除以2,将二进制数向右移,左边补零
>>> : 无符号右移,忽略符号位,空位都以0补齐
下面来看看这些移位运算都是怎样使用的:
我们把上面的结果对齐一下:
看了上面的demo,现在是不是对左移和右移了解了很多了呢
对于:>>>
无符号右移,忽略符号位,空位都以0补齐
value >>> num -- num 指定要移位值value 移动的位数。
无符号右移的规则只记住一点:忽略了符号位扩展,0补最高位 无符号右移运算符>>> 只是对32位和64位的值有意义。
<< : 左移运算符,num << 1,相当于num乘以2(2的一次幂),将二进制数向左移,右边补零。
>> : 右移运算符,num >> 1,相当于num除以2,将二进制数向右移,左边补零
>>> : 无符号右移,忽略符号位,空位都以0补齐
下面来看看这些移位运算都是怎样使用的:
public class Test { public static void main(String[] args) { int number = 10; //原始数二进制 printInfo(number); number = number << 1; //左移一位 printInfo(number); number = number >> 1; //右移一位 printInfo(number); } /** * 输出一个int的二进制数 * @param num */ private static void printInfo(int num){ System.out.println(Integer.toBinaryString(num)); } }运行结果为:
1010 10100 1010
我们把上面的结果对齐一下:
43210 位数 -------- 1010 十进制:10 原始数 number 10100 十进制:20 左移一位 number = number << 1; 1010 十进制:10 右移一位 number = number >> 1;
看了上面的demo,现在是不是对左移和右移了解了很多了呢
对于:>>>
无符号右移,忽略符号位,空位都以0补齐
value >>> num -- num 指定要移位值value 移动的位数。
无符号右移的规则只记住一点:忽略了符号位扩展,0补最高位 无符号右移运算符>>> 只是对32位和64位的值有意义。
相关文章推荐
- java基础之集合框架总结篇
- Java基础语法
- springmvc学习笔记(四)访问静态资源
- java命令模式
- java泛型方法
- Thinking in java 之'数据初始化'
- Java简单聊天室
- 从零开始学Java自己利用接口和集合框架做的简单图书管理系统
- 排序算法(Java语言)——归并排序
- java去除重复的字符串和移除不想要的字符串
- jdk、jre和jvm
- 【leetcode】Ugly Number【java】
- struts2 报错:java.lang.NullPointerException: Source must not be null
- metaq spring配置
- Spring EL hello world example
- Java中常见概念
- leetcode-124:Binary Tree Maximum Path Sum(Java)
- leetcode-124:Binary Tree Maximum Path Sum(Java)
- java集合
- 23种设计模式(Java)