• ava中有三种移位运算符


    转自:http://www.cnblogs.com/hongten/p/hongten_java_yiweiyunsuangfu.html

    <<      :     左移运算符,num << 1,相当于num乘以2

    >>      :     右移运算符,num >> 1,相当于num除以2

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

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

    复制代码
     1 /**
     2  * 
     3  */
     4 package com.b510.test;
     5 
     6 /**
     7  * @author Jone Hongten
     8  * @create date:2013-11-2
     9  * @version 1.0
    10  */
    11 public class Test {
    12 
    13     public static void main(String[] args) {
    14         int number = 10;
    15         //原始数二进制
    16         printInfo(number);
    17         number = number << 1;
    18         //左移一位
    19         printInfo(number);
    20         number = number >> 1;
    21         //右移一位
    22         printInfo(number);
    23     }
    24     
    25     /**
    26      * 输出一个int的二进制数
    27      * @param num
    28      */
    29     private static void printInfo(int num){
    30         System.out.println(Integer.toBinaryString(num));
    31     }
    32 }
    复制代码

    运行结果为:

    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位的值有意义

  • 相关阅读:
    Codeforces Round #622 (Div. 2)
    Knapsack Cryptosystem 牛客团队赛
    HDU 2586(LCA欧拉序和st表)
    P3865 【模板】ST表
    P2023 [AHOI2009]维护序列 区间加乘模板
    P1558 色板游戏 线段树(区间修改,区间查询)
    Codeforces Round #621 (Div. 1 + Div. 2) D
    Codeforces Round #620 (Div. 2) E
    Educational Codeforces Round 82 (Rated for Div. 2)
    洛谷P1638 逛画展
  • 原文地址:https://www.cnblogs.com/beijingstruggle/p/6633513.html
Copyright © 2020-2023  润新知