【位操作笔记】位合并 普通方式

2024-06-22 04:08

本文主要是介绍【位操作笔记】位合并 普通方式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

位合并(Merge bits) 普通方式

通过掩码把两个数进行位合并。例如一个数为0x23,另一个数为0x65,假设合并的数要取第一个数的高4位,第二个数的低4位,那么合并后的数就是0x25。

算法说明

该算法通过先与掩码,再进行或操作完成。

实现代码

non_masked_val和masked_val是两个要进行合并的数,mask是掩码。

non_masked_val是合并非掩码位,masked_val是合并掩码位。

实现方式为:

unsigned int Merge_bits(unsigned int non_masked_val, unsigned int masked_val, unsigned int mask)
{return (non_masked_val & ~mask) | (masked_val & mask);
}

算法计算过程

第一步,~mask 。

掩码取反。

第二步,non_masked_val & ~mask。

mask的取反值与non_masked_val 进行与操作,留下非掩码位的值。

第三步, masked_val & mask。

masked_val与mask进行与操作,留下掩码位的值。

第四步,(non_masked_val & ~mask) | (masked_val & mask)

第二步和第三步的值进行或操作完成合并。

计算示例

例如:

non_masked_val = 0x7AC34B64

masked_val = 0x98BF537A

mask = 0x0000FFFF

第一步

~mask = ~0x0000FFFF = 0xFFFF0000~   0000 0000 0000 0000 1111 1111 1111 1111
-------------------------------------------1111 1111 1111 1111 0000 0000 0000 0000

第二步

non_masked_val & ~mask
0x7AC34B64 & 0xFFFF0000 = 0x7AC30000‭0111 1010 1100 0011 0100 1011 0110 0100‬
&   1111 1111 1111 1111 0000 0000 0000 0000
-------------------------------------------‭0111 1010 1100 0011 0000 0000 0000 0000

第三步

masked_val & mask
0x98BF537A & 0x0000FFFF = 0x0000537A1001 1000 1011 1111 0101 0011 0111 1010
&   0000 0000 0000 0000 1111 1111 1111 1111
-------------------------------------------0000 0000 0000 0000 0101 0011 0111 1010

第四步

0x7AC30000 & 0x0000537A = 0x7AC3537A0111 1010 1100 0011 0000 0000 0000 0000
|   0000 0000 0000 0000 0101 0011 0111 1010
-------------------------------------------0111 1010 1100 0011 0101 0011 0111 1010

得到两个数合并的数0x7AC3537A。


[参考资料]

Bit Twiddling Hacks By Sean Eron Anderson


本文链接:https://blog.csdn.net/u012028275/article/details/117400008

这篇关于【位操作笔记】位合并 普通方式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1083242

相关文章

C#实现一键批量合并PDF文档

《C#实现一键批量合并PDF文档》这篇文章主要为大家详细介绍了如何使用C#实现一键批量合并PDF文档功能,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言效果展示功能实现1、添加文件2、文件分组(书签)3、定义页码范围4、自定义显示5、定义页面尺寸6、PDF批量合并7、其他方法

HTTP 与 SpringBoot 参数提交与接收协议方式

《HTTP与SpringBoot参数提交与接收协议方式》HTTP参数提交方式包括URL查询、表单、JSON/XML、路径变量、头部、Cookie、GraphQL、WebSocket和SSE,依据... 目录HTTP 协议支持多种参数提交方式,主要取决于请求方法(Method)和内容类型(Content-Ty

使用shardingsphere实现mysql数据库分片方式

《使用shardingsphere实现mysql数据库分片方式》本文介绍如何使用ShardingSphere-JDBC在SpringBoot中实现MySQL水平分库,涵盖分片策略、路由算法及零侵入配置... 目录一、ShardingSphere 简介1.1 对比1.2 核心概念1.3 Sharding-Sp

Spring创建Bean的八种主要方式详解

《Spring创建Bean的八种主要方式详解》Spring(尤其是SpringBoot)提供了多种方式来让容器创建和管理Bean,@Component、@Configuration+@Bean、@En... 目录引言一、Spring 创建 Bean 的 8 种主要方式1. @Component 及其衍生注解

python中的显式声明类型参数使用方式

《python中的显式声明类型参数使用方式》文章探讨了Python3.10+版本中类型注解的使用,指出FastAPI官方示例强调显式声明参数类型,通过|操作符替代Union/Optional,可提升代... 目录背景python函数显式声明的类型汇总基本类型集合类型Optional and Union(py

Linux系统管理与进程任务管理方式

《Linux系统管理与进程任务管理方式》本文系统讲解Linux管理核心技能,涵盖引导流程、服务控制(Systemd与GRUB2)、进程管理(前台/后台运行、工具使用)、计划任务(at/cron)及常用... 目录引言一、linux系统引导过程与服务控制1.1 系统引导的五个关键阶段1.2 GRUB2的进化优

IDEA与MyEclipse代码量统计方式

《IDEA与MyEclipse代码量统计方式》文章介绍在项目中不安装第三方工具统计代码行数的方法,分别说明MyEclipse通过正则搜索(排除空行和注释)及IDEA使用Statistic插件或调整搜索... 目录项目场景MyEclipse代码量统计IDEA代码量统计总结项目场景在项目中,有时候我们需要统计

C#和Unity中的中介者模式使用方式

《C#和Unity中的中介者模式使用方式》中介者模式通过中介者封装对象交互,降低耦合度,集中控制逻辑,适用于复杂系统组件交互场景,C#中可用事件、委托或MediatR实现,提升可维护性与灵活性... 目录C#中的中介者模式详解一、中介者模式的基本概念1. 定义2. 组成要素3. 模式结构二、中介者模式的特点

详解Java中三种状态机实现方式来优雅消灭 if-else 嵌套

《详解Java中三种状态机实现方式来优雅消灭if-else嵌套》这篇文章主要为大家详细介绍了Java中三种状态机实现方式从而优雅消灭if-else嵌套,文中的示例代码讲解详细,感兴趣的小伙伴可以跟... 目录1. 前言2. 复现传统if-else实现的业务场景问题3. 用状态机模式改造3.1 定义状态接口3

Java异常捕获及处理方式详解

《Java异常捕获及处理方式详解》异常处理是Java编程中非常重要的一部分,它允许我们在程序运行时捕获并处理错误或不预期的行为,而不是让程序直接崩溃,本文将介绍Java中如何捕获异常,以及常用的异常处... 目录前言什么是异常?Java异常的基本语法解释:1. 捕获异常并处理示例1:捕获并处理单个异常解释: