您现在的位置是:首页 > 文章详情

Java 基础 之 位运算

日期:2018-07-21点击:524

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 然后在移动
        */
    }
}

http://www.verejava.com/?id=16992602784016

原文链接:https://yq.aliyun.com/articles/617330
关注公众号

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。

持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。

文章评论

共有0条评论来说两句吧...

文章二维码

扫描即可查看该文章

点击排行

推荐阅读

最新文章