当前位置: 首页 > news >正文

Java的位运算

目录

1 Java中支持的位运算

2 位运算规则

3 逻辑运算

3.1 与运算(&)

3.2 或运算(|)

3.3 异或运算(^)

3.3 取反运算(~)

4 位移操作

4.1 左移(<<)

4.2 右移(>>)

4.3 无符号右移(>>>)


1 Java中支持的位运算

位与(&):二元运算符,两个为1时结果为1,否则为0。

位或(|):二元运算符,两个其中有一个为1时结果就为1,否则为0。

位异或(^):二元运算符,两个数同时为1或0时结果为1,否则为0。

位取非(~):一元运算符,取反操作。

左移(<<):一元运算符,按位左移一定的位置。高位溢出,低位补符号位,符号位不变。

右移(>>):一元运算符,按位右移一定的位置。高位补符号位,符号位不变,低位溢出。

无符号右移(>>>):一元运算符,符号位(即最高位)保留,其它位置向右移动,高位补零,低位溢出。

2 位运算规则

Java数值运算过程中都是先将十进制转换为二进制然后再进行运算,再把二进制数据转换为十进制展现给用户。二进制运算规则如下:

对于有符号的而言,最高位为符号位,0表示正数,1表示负数。

正数的原码,反码和补码都一样,三码合一

负数的反码:符号位保持不限,其他位取反,负数的补码:补码 + 1

0的反码和补码都是0。

计算机的运算的时候,都是将原码转成补码进行运算的。

下面以 -1 为例子展示原码、反码和补码的转换关系(以int数据类型为例,int类型在Java中占4字节):

https://img-blog.csdnimg.cn/img_convert/1e49517df17c312ab66becac0d064f95.png

3 逻辑运算

3.1与运算(&)

3.1.1 运算规则

两个数相同位置的比特进行与运算,若两个位置均为1,那么结果就为1,否者为0

https://img-blog.csdnimg.cn/img_convert/d919984e859fbb7837794e3b021d919f.png

3.1.2 运算流程

以 4 & -5 = 0为例子展示运算流程:

1 因为4为正数,所以原码和补码相同,即4的补码为:00000000 0000000 00000000 00000100

2 因为-5为负数,所以需要进行原码 >>> 反码 >>> 补码的转换

  1)原码:10000000 00000000 00000000 00000101

  2)反码:11111111 11111111 11111111 11111010

  3)补码:11111111 11111111 11111111 11111011

3将4和-5的补码进行 & 运算:00000000 0000000 00000000 00000100

                11111111 11111111 11111111 11111011         &

                00000000 00000000 00000000 00000000

4得到的补码结果为:00000000 00000000 00000000 00000000。所以结果为0

3.2 或运算(|)

3.2.1 运算规则

两个数相同位置的比特进行或运算,若其中一个为1则结果为1,否个结果为0

https://img-blog.csdnimg.cn/img_convert/c2d847d3fdc88789e89b5238873f783b.png

3.2.2 运算流程

以 -2 | 5 = -1为例展示运算流程:

1. -2为负数,需要进行原码 > 反码 > 补码的转换。转换步骤如下: 

  1)原码:10000000 00000000 00000000 00000010

  2)符号位不变,其他位置取反得反码:11111111 11111111 11111111 11111101

  3)在反码的基础上+1得到补码: 11111111 11111111 11111111 11111110

2. 5为正数,补码和反码一致,所以5的补码为:00000000 00000000 00000000 00000101

3. 将-2 和 5 的补码进行或运算: 11111111 11111111 11111111 11111110

             |     00000000 00000000 00000000 00000101

                 11111111 11111111 11111111 11111111

4.  根据上面的运算得到补码结果为:11111111 11111111 11111111 11111111

5.  结果显然是一个负数,而负数的补码和原码不一致,所以需要将补码结果转换为原码才能得到最终的结果

6. 补码转原码的过程是跟原码转补码相反的过程,具体过程如下:

  1)补码:11111111 11111111 11111111 11111111

  2)补码 -1 得到反码:11111111 11111111 11111111 11111110

  3)符号位不变,其他位置取反得:10000000 00000000 00000000 00000001

7. 最终得到的原码结果为 10000000 00000000 00000000 00000001,转成十进制为 -1

3.3 异或运算(^)

3.3.1 运算规则

两个数相同位置的比特进行或运算,若两个数均为0或1,则结果为0,否者为1.

https://img-blog.csdnimg.cn/img_convert/af0b686f299c761f1452c1f493c6b099.png

3.3.2 运算流程

以 1 ^ -5 = 6 为例,具体运算流程如下:

1. 1的补码为:00000000 00000000 00000000 00000001

2. -5的补码为:11111111 11111111 11111111 11111011(可参考与运算给出的流程)

3. 两个补码运算:  

         00000000  00000000  00000000  00000001

       ^      11111111    11111111   11111111    11111011

            11111111    11111111   11111111    11111010

4. 得到的补码结果为:11111111   11111111  11111111    11111010

5. 补码为负数,需要转换成原码:

      1)补码:11111111   11111111  11111111     11111010

      2)反码:11111111   11111111  11111111     11111001

                     3)原码: 10000000   00000000   00000000    000000110

6. 由原码:10000000 00000000 00000000 000000110,得出最终的时间结果为 -6.

3.3 取反运算(~)

3.3.1 运算规则

若位数为0,则取反后为1,若为1,取反后为0

https://img-blog.csdnimg.cn/img_convert/324790ea72d40fe791c2d539058f314c.png

3.3.2 运算流程

以~2 = -3为例运算流程如下:

1.  2的原码为:00000000 00000000 00000000 00000010

2. 的补码跟原码一致也为:00000000 00000000 00000000 00000010

3. 取反:111111111 11111111 11111111 11111101

4. 取反后的结果仍未补码,此时补码为负数,则需要转成原码

5. 11111111 11111111 11111111 11111101 - 1 得到反码:11111111 11111111 11111111 11111100

6. 11111111 11111111 11111111 11111100 符号位不变,其他位置取反得到原码为:10000000 00000000 00000000 00000011

7. 10000000 00000000 00000000 00000011 转成十进制结果为 -3       

4 位移操作

4.1 左移(<<)

规则:符号位不变,高位溢出截断,低位补零。比如 -1 << 2 = -4 (为方便讲解,图示的补码为-1)

https://img-blog.csdnimg.cn/img_convert/4ef021927293f3556ddc90680103acca.png

4.2 右移(>>)

规则:符号位不变,低位溢出截断,高位用符号位填充。如:8 >> 2 = 2。

https://img-blog.csdnimg.cn/img_convert/ecfedf293145679ee9a2472f64c8d1d7.png

4.3 无符号右移(>>>)

规则:高位填充0,低位溢出。如-1>>>1=2147483647

https://img-blog.csdnimg.cn/img_convert/b7f2b4b2aae2b6f7f8121e3c5bf49ee5.png

相关文章:

Java的位运算

目录 1 Java中支持的位运算 2 位运算规则 3 逻辑运算 3.1 与运算&#xff08;&&#xff09; 3.2 或运算&#xff08;|&#xff09; 3.3 异或运算&#xff08;^&#xff09; 3.3 取反运算&#xff08;~&#xff09; 4 位移操作 4.1 左移&#xff08;<<&#…...

FastDFS分布式文件存储

FastDFS文件上传 简介&#xff1a; 主要解决&#xff1a;大容量的文件存储和高并发访问的问题 论坛&#xff1a;https://bbs.chinaunix.net 下载网站&#xff1a;https://sourceforge.net/projects/fastdfs/files/ 安装参考&#xff1a;https://www.cnblogs.com/cxygg/p/1…...

Android的AAC架构

AAC Android Architecture Components的简称&#xff0c;是一套用来搭建具有生命周期感知架构的系列组件&#xff0c;在2017年 GoogleI/O大会上发布。 dependencies {def lifecycle_version "2.2.0"implementation "androidx.lifecycle:lifecycle-livedata-ktx…...

高功率激光切割中不良现象的排除技巧

高功率切割市场现状 随着激光行业的发展和下游产业需求的变化&#xff0c;高功率的激光切割设备已逐渐成为市场关注的热点。高功率激光切割凭着速度和厚度上无可比拟的优势&#xff0c;目前已获得了市场的广泛认可。 但由于高功率激光切割技术尚处于普及的初级阶段&#xff0c;…...

MySQL-----复合查询

文章目录 前言一、基本查询回顾二、 多表查询解决多表查询的思路 三、自连接四、子查询1. 单行子查询2. 多行子查询3. 多列子查询4. 在from子句中使用子查询5. 合并查询5.1 union5.2 unoin all 总结 前言 前面的学习中,对于mysql表的查询都是对一张表进行查询,在实际开发中这远…...

10.Yarn概述

如果说HDFS是存储&#xff0c;则Yarn就是cpu和内存&#xff0c;mapreduce就是程序。 1.基础架构 复习&#xff1a; 1.Container就是一个容器&#xff0c;其中封装了需要使用的内存与cpu 2.每当提交一个job,就会产生一个appMaster(总指挥),app Master负责其他container里面的…...

MFC实现背景透明,控件不透明的对话框,且点击图片有事件响应

最终成果&#xff1a;背景半透明、但是控件不透明的对话框。 对话框上用图片代表功能&#xff0c;当点击图片时&#xff0c;响应点击事件&#xff0c;弹出相对应的对话框。 对话框固定大小&#xff0c;不可放大缩小&#xff0c;以免影响图片的显示数量。 步骤一&#xff1a;背景…...

案例01-tlias智能学习辅助系统01-增删改查+参数传递

目录 1、需求说明&#xff1a;实现对部门表和员工表的增删改查 2、环境搭建 3、部门管理 3.1 查询部门 3.2 前后端联调 3.3 删除部门 3.4 新增部门 3.5 根据ID查询数据 3.5 修改部门 总结&#xff08;Controller层参数接收&#xff09;&#xff1a; 4、员工管理 4.…...

Spring之Bean的配置与实例

Spring之Bean的配置与实例 一、Bean的基础配置1. Bean基础配置【重点】配置说明代码演示运行结果 2. Bean别名配置配置说明代码演示打印结果 3. Bean作用范围配置【重点】配置说明代码演示打印结果 二、Bean的实例化1. Bean是如何创建的2. 实例化Bean的三种方式2.1 构造方法方式…...

“不保留活动”打开,导致app返回前台崩溃问题解决

问题描述 不保留活动开关打开&#xff0c;把app切入后台&#xff0c;会导致当前展示的Activity被回收&#xff0c;切到前台后重建。 我们有个业务场景是&#xff0c;Activity里面有个ViewPager2&#xff0c;VP里面放Fragment&#xff0c;Fragment的展示需要在Activity中做一些…...

解读vue3源码(3)——watch

Vue3的watch底层源码主要是通过使用Proxy对象来实现的。在Vue3中&#xff0c;每个组件实例都会有一个watcher实例&#xff0c;用于监听组件数据的变化。当组件数据发生变化时&#xff0c;watcher实例会触发回调函数&#xff0c;从而更新组件的视图。 Vue3的watch底层源码主要涉…...

优秀简历的HR视角:怎样打造一份称心如意的简历?

简历的排版应该简洁工整&#xff0c;注重细节。需要注意对齐和标点符号的使用&#xff0c;因为在排版上的细节需要下很大功夫。除此之外&#xff0c;下面重点讲述几点简历内容需要注意的地方。 要点1&#xff1a;不相关的不要写。 尤其是与应聘岗位毫不相关的实习经历&#x…...

系统集成项目管理工程师——考试重点(三)项目管理一般知识

1.项目定义&#xff1a; 为达到特定的目的&#xff0c;使用一定资源&#xff0c;在确定的期间内&#xff0c;为特定发起人提供独特的产品、服务或成果而进行的一系列相互关联的活动的集合。 2.项目目标&#xff1a; 成果性目标&#xff1a;项目产品本身 约束性目标&…...

为什么医疗保健需要MFT来帮助保护EHR文件传输

毫无疑问&#xff0c;医疗保健行业需要EHR技术来处理患者&#xff0c;设施&#xff0c;提供者等之间的敏感患者信息。但是&#xff0c;如果没有安全的MFT解决方案&#xff0c;您将无法安全地传输患者文件&#xff0c;从而使您的运营面临遭受数据泄露&#xff0c;尴尬&#xff0…...

对项目总体把控不足,项目经理应该怎么办?

公司现状&#xff1a;项目人员紧缺&#xff0c;只有两人了解此项目技术细节&#xff0c;其中一个不常驻现场&#xff0c;另一个是执行项目经理李伟。 项目经理王博是公司元老&#xff0c;同时负责多个项目&#xff0c;工作比较忙&#xff0c;不常驻现场&#xff0c;没有参加过…...

【学习笔记】CF603E Pastoral Oddities

先不考虑数据结构部分&#xff0c;尝试猜一下结论。 结论&#xff1a;一个连通块有解当且仅当连通块的度数为偶数。 然后这题要你最大边权最小。最无脑的方法就是直接上 lct \text{lct} lct。真省事啊 我第一眼想到的还是整体二分。这玩意非常好写。 但是为什么也可以用线段…...

如何使用ESP32-CAM构建一个人脸识别系统

有许多人识别系统使用签名、指纹、语音、手部几何、人脸识别等来识别人&#xff0c;但除了人脸识别系统。 人脸识别系统不仅可以用于安全目的来识别公共场所的人员&#xff0c;还可以用于办公室和学校的考勤目的。 在这个项目中&#xff0c;我们将使用 ESP32-CAM 构建一个人脸识…...

JavaWeb分页条件查询参数特殊字符处理

问题背景 在项目开发过程中&#xff0c;基本都会有列表条件查询&#xff0c;例如用户管理会有通过用户姓名模糊查询用户&#xff0c;课程管理会有课程名称模糊查询课程等等。 而查询过程中如果用户在界面上输入一些特殊字符&#xff0c;例如&#xff1a;%_等等&#xff0c;这…...

ubuntu18服务安装

一、JDK安装 将jdk解压缩到该目录 /opt/ sudo tar -zxvf jdk-8u261-linux-x64.tar.gz -C /opt/ #重命名 cd /opt sudo mv jdk-8u261-linux-x64 jdk_8 修改环境变量 sudo vi ~/.bashrc #在文件最后追加以下文本 #进入编辑器后输入以下指令&#xff1a; #1. G //将光标移到最后一…...

这些使用工具大推荐,现在知道不晚

1.Snip Snip是一款截图软件&#xff0c;它突出的优点就是可以制作滚动截图。 例如&#xff1a;对整个网页进行截图&#xff0c;使用Snip即可轻松获取&#xff0c;无需处理水印。 2.Sleep Cycle 快节奏、高压力的生活导致我们越来越晚睡觉&#xff0c;睡眠质量越来越差。 想提…...

基于算法竞赛的c++编程(28)结构体的进阶应用

结构体的嵌套与复杂数据组织 在C中&#xff0c;结构体可以嵌套使用&#xff0c;形成更复杂的数据结构。例如&#xff0c;可以通过嵌套结构体描述多层级数据关系&#xff1a; struct Address {string city;string street;int zipCode; };struct Employee {string name;int id;…...

uniapp 对接腾讯云IM群组成员管理(增删改查)

UniApp 实战&#xff1a;腾讯云IM群组成员管理&#xff08;增删改查&#xff09; 一、前言 在社交类App开发中&#xff0c;群组成员管理是核心功能之一。本文将基于UniApp框架&#xff0c;结合腾讯云IM SDK&#xff0c;详细讲解如何实现群组成员的增删改查全流程。 权限校验…...

Python|GIF 解析与构建(5):手搓截屏和帧率控制

目录 Python&#xff5c;GIF 解析与构建&#xff08;5&#xff09;&#xff1a;手搓截屏和帧率控制 一、引言 二、技术实现&#xff1a;手搓截屏模块 2.1 核心原理 2.2 代码解析&#xff1a;ScreenshotData类 2.2.1 截图函数&#xff1a;capture_screen 三、技术实现&…...

深度学习在微纳光子学中的应用

深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向&#xff1a; 逆向设计 通过神经网络快速预测微纳结构的光学响应&#xff0c;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…...

零门槛NAS搭建:WinNAS如何让普通电脑秒变私有云?

一、核心优势&#xff1a;专为Windows用户设计的极简NAS WinNAS由深圳耘想存储科技开发&#xff0c;是一款收费低廉但功能全面的Windows NAS工具&#xff0c;主打“无学习成本部署” 。与其他NAS软件相比&#xff0c;其优势在于&#xff1a; 无需硬件改造&#xff1a;将任意W…...

脑机新手指南(八):OpenBCI_GUI:从环境搭建到数据可视化(下)

一、数据处理与分析实战 &#xff08;一&#xff09;实时滤波与参数调整 基础滤波操作 60Hz 工频滤波&#xff1a;勾选界面右侧 “60Hz” 复选框&#xff0c;可有效抑制电网干扰&#xff08;适用于北美地区&#xff0c;欧洲用户可调整为 50Hz&#xff09;。 平滑处理&…...

基于距离变化能量开销动态调整的WSN低功耗拓扑控制开销算法matlab仿真

目录 1.程序功能描述 2.测试软件版本以及运行结果展示 3.核心程序 4.算法仿真参数 5.算法理论概述 6.参考文献 7.完整程序 1.程序功能描述 通过动态调整节点通信的能量开销&#xff0c;平衡网络负载&#xff0c;延长WSN生命周期。具体通过建立基于距离的能量消耗模型&am…...

反向工程与模型迁移:打造未来商品详情API的可持续创新体系

在电商行业蓬勃发展的当下&#xff0c;商品详情API作为连接电商平台与开发者、商家及用户的关键纽带&#xff0c;其重要性日益凸显。传统商品详情API主要聚焦于商品基本信息&#xff08;如名称、价格、库存等&#xff09;的获取与展示&#xff0c;已难以满足市场对个性化、智能…...

工程地质软件市场:发展现状、趋势与策略建议

一、引言 在工程建设领域&#xff0c;准确把握地质条件是确保项目顺利推进和安全运营的关键。工程地质软件作为处理、分析、模拟和展示工程地质数据的重要工具&#xff0c;正发挥着日益重要的作用。它凭借强大的数据处理能力、三维建模功能、空间分析工具和可视化展示手段&…...

高危文件识别的常用算法:原理、应用与企业场景

高危文件识别的常用算法&#xff1a;原理、应用与企业场景 高危文件识别旨在检测可能导致安全威胁的文件&#xff0c;如包含恶意代码、敏感数据或欺诈内容的文档&#xff0c;在企业协同办公环境中&#xff08;如Teams、Google Workspace&#xff09;尤为重要。结合大模型技术&…...