java中移位运算符<< >>

来源:互联网 发布:java aes算法 编辑:程序博客网 时间:2024/05/30 23:03

转自:http://www.cnblogs.com/hongten/p/hongten_java_yiweiyunsuangfu.html
java中有三种移位运算符

<<      :     左移运算符,num << 1,是在转换成二进制运算中向左位移,相当于num乘以2>>      :     右移运算符,num >> 1,是在转换成二进制运算中向右位移,相当于num除以2>>>    :     无符号右移,忽略符号位,空位都以0补齐

下面来看看这些移位运算都是怎样使用的

/** *  */package com.b510.test;/** * @author Jone Hongten * @create date:2013-11-2 * @version 1.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));    }}

运行结果为:

1010101001010

我们把上面的结果对齐一下:

43210 位数 - - 1010 十进制:10 原始数 number 10100 十进制:20 左移一位 number = number << 1; 1010 十进制:10 右移一位 number = number >> 1;

看了上面的demo,现在是不是对左移和右移了解了很多了呢

对于:>>>

无符号右移,忽略符号位,空位都以0补齐

value >>> num – num 指定要移位值value 移动的位数。

无符号右移的规则只记住一点:忽略了符号位扩展,0补最高位 无符号右移运算符>>> 只是对32位和64位的值有意义

原创粉丝点击