Java 位运算系列之通过位运算操作状态

本文介绍了Java中的位运算,包括与(&)、或(|)和异或(^)运算,并通过示例展示了如何利用这些运算符高效地管理对象的状态,避免大量条件判断。通过设置二进制中特定位置的1来表示不同状态,结合位运算实现状态的添加、检查和删除。

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

文章目录

回顾

首先来回顾一下位运算,什么是位运算呢?

位运算就是直接对整数在内存中的二进制位进行操作。

在 Java 语言中,位运算有如下这些:

  • 左移(<<)。
  • 右移(>>)。
  • 无符号右移(>>>)。
  • 与(&)。
  • 或(|)。
  • 非(~)。
  • 异或(^)。

在本篇文章中,我们所需要用到的有如下几个(其他的后续文章再讲):

  • &(与运算):只有当两方都为 true 时,结果才是 true,否则为 false。
  • |(或运算):只要当一方为 true 时,结果就是 true,否则为 false。
  • ^(异或运算):只要两方不同,结果就是 true,否则为 false。

以 true、false 为例:

true & true  = true
true & false = false

true | false = true;
false | false = false;

true ^ true = false;
true ^ false = true;

以数字运算为例:

6 & 4 = ?
6 | 4  = ?
6 ^ 4 = ?

当以数字运算时,我们首先需要知道这些数字的二进制,假设 6 是 int 类型,那么其二进制如下:

00000000 00000000 00000000 00000110

在 Java 中,int 占了 4 个字节(Byte),一个字节呢又等于 8 个 Bit 位。所以 int 类型的二进制表

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值