二进制的简单运算了解

本文介绍了二进制的基本运算,包括A和B的按位与(&)、按位或(|)、异或(^)和取反(~),并展示了如何通过位操作理解乘法和除法。同时,详细解释了左移(<<)和右移(>>)的概念及其在数值表示中的应用实例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

二进制的简单运算了解


  • 二进制,位运算 &(和,and) |(或,or) ~(取反)

A=0000 1100

B=0011 1101

(A和B)   A&B=0000 1100 //相对应 位 如果都为1才是1,有一个为0就是0

(A或B)   A|B=0011 1101 //相对应 位 如果都为0才是0,有一个为1就是1

(非A即B) A^B=0011 0001 //相对应 位 如果相同都为1、0才是0,有一个为1就是1

(取反)  ~B=1111 0010 //对应 位 如果为1就是0,如果为0就是1


  • 二进制的 左移<< 右移>>

  • 2*8=16 2.2.2.2

    <<左移 *2  >>右移 /2

    00000000  0

    00000001  1

    00000010  2

    00000011  3

    00000100  4

    00001000  8

    00010000  16

System.out.println(2<<3);//2左移三位
        // 0000 0010    2
        // 0001 0000    16
        System.out.println(16>>3);//16右移三位
        System.out.println("--------");
        System.out.println(64>>3);
        // 0000 1000    64
        // 0100 0000    8

        System.out.println(8>>2);
        // 0000 1000    8
        // 0000 0010    2
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值