【ARM 嵌入式 C 入门及渐进 12.2 -- 将数值的第 0 位到 n 位清零】

2024-05-12 10:28

本文主要是介绍【ARM 嵌入式 C 入门及渐进 12.2 -- 将数值的第 0 位到 n 位清零】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


请阅读【嵌入式开发学习必备专栏】


文章目录

    • 将数值的第 0 位到 n位清零

将数值的第 0 位到 n位清零

要定义一个宏VAL_CLR_BITS(val, n),该宏将变量val的第0位到第n位清零(包括第n位),其余位的值保持不变,我们可以使用位操作来实现这个功能。以下是宏的一个可能实现:

#define VAL_CLR_BITS(val, n) ((val) & ~((1ULL << ((n) + 1)) - 1))

这个宏的工作原理如下:

  1. 1ULL << ((n) + 1):首先将1(使用unsigned long long类型以确保宽度)左移n+1位。这样做的目的是创建一个值,其中第0位到第n位都是1,其余位都是0。
  2. -1:然后,从这个值中减去1,这会将第0位到第n位变为0,而第n+1位变为1(如果存在),其余高位保持为0。
  3. ~:接着,对上一步的结果取反,这会将第0位到第n位变为1,其余位保持不变。
  4. &:最后,使用与操作&val与上一步得到的掩码进行位与操作。由于掩码中第0位到第n位为0,其余位为1,因此这一操作将清零val的第0位到第n位,而保留其余位的值不变。
    这是一个示例代码,演示如何使用VAL_CLR_BITS宏:
#include <stdio.h>
#define VAL_CLR_BITS(val, n) ((val) & ~((1ULL << ((n) + 1)) - 1))int main(void) 
{unsigned int val = 0xFFFF; // 16位宽的值,初始全为1unsigned int n = 3; // 将第0位到第3位清零unsigned int result = VAL_CLR_BITS(val, n);printf("Original value: 0x%X\n", val);printf("After masking: 0x%X\n", result);return 0;
}

这段代码将输出val的原始值和应用VAL_CLR_BITS宏后的结果。在这个示例中,val初始值为0xFFFF,即所有位都是1。应用VAL_CLR_BITS(val, 3)后,结果将是0xFFF0,即第0位到第3位被清零。

这篇关于【ARM 嵌入式 C 入门及渐进 12.2 -- 将数值的第 0 位到 n 位清零】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

从入门到精通MySQL联合查询

《从入门到精通MySQL联合查询》:本文主要介绍从入门到精通MySQL联合查询,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下... 目录摘要1. 多表联合查询时mysql内部原理2. 内连接3. 外连接4. 自连接5. 子查询6. 合并查询7. 插入查询结果摘要前面我们学习了数据库设计时要满

从入门到精通C++11 <chrono> 库特性

《从入门到精通C++11<chrono>库特性》chrono库是C++11中一个非常强大和实用的库,它为时间处理提供了丰富的功能和类型安全的接口,通过本文的介绍,我们了解了chrono库的基本概念... 目录一、引言1.1 为什么需要<chrono>库1.2<chrono>库的基本概念二、时间段(Durat

SQLite3 在嵌入式C环境中存储音频/视频文件的最优方案

《SQLite3在嵌入式C环境中存储音频/视频文件的最优方案》本文探讨了SQLite3在嵌入式C环境中存储音视频文件的优化方案,推荐采用文件路径存储结合元数据管理,兼顾效率与资源限制,小文件可使用B... 目录SQLite3 在嵌入式C环境中存储音频/视频文件的专业方案一、存储策略选择1. 直接存储 vs

嵌入式数据库SQLite 3配置使用讲解

《嵌入式数据库SQLite3配置使用讲解》本文强调嵌入式项目中SQLite3数据库的重要性,因其零配置、轻量级、跨平台及事务处理特性,可保障数据溯源与责任明确,详细讲解安装配置、基础语法及SQLit... 目录0、惨痛教训1、SQLite3环境配置(1)、下载安装SQLite库(2)、解压下载的文件(3)、

解析C++11 static_assert及与Boost库的关联从入门到精通

《解析C++11static_assert及与Boost库的关联从入门到精通》static_assert是C++中强大的编译时验证工具,它能够在编译阶段拦截不符合预期的类型或值,增强代码的健壮性,通... 目录一、背景知识:传统断言方法的局限性1.1 assert宏1.2 #error指令1.3 第三方解决

从入门到精通MySQL 数据库索引(实战案例)

《从入门到精通MySQL数据库索引(实战案例)》索引是数据库的目录,提升查询速度,主要类型包括BTree、Hash、全文、空间索引,需根据场景选择,建议用于高频查询、关联字段、排序等,避免重复率高或... 目录一、索引是什么?能干嘛?核心作用:二、索引的 4 种主要类型(附通俗例子)1. BTree 索引(

Redis 配置文件使用建议redis.conf 从入门到实战

《Redis配置文件使用建议redis.conf从入门到实战》Redis配置方式包括配置文件、命令行参数、运行时CONFIG命令,支持动态修改参数及持久化,常用项涉及端口、绑定、内存策略等,版本8... 目录一、Redis.conf 是什么?二、命令行方式传参(适用于测试)三、运行时动态修改配置(不重启服务

k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)

《k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)》本文记录在K8s上运行的MySQL/MariaDB备份方案,通过工具容器执行mysqldump,结合定时任务实... 目录前言一、获取需要备份的数据库的信息二、备份步骤1.准备工作(X86)1.准备工作(arm)2.手

MySQL DQL从入门到精通

《MySQLDQL从入门到精通》通过DQL,我们可以从数据库中检索出所需的数据,进行各种复杂的数据分析和处理,本文将深入探讨MySQLDQL的各个方面,帮助你全面掌握这一重要技能,感兴趣的朋友跟随小... 目录一、DQL 基础:SELECT 语句入门二、数据过滤:WHERE 子句的使用三、结果排序:ORDE

Python中OpenCV与Matplotlib的图像操作入门指南

《Python中OpenCV与Matplotlib的图像操作入门指南》:本文主要介绍Python中OpenCV与Matplotlib的图像操作指南,本文通过实例代码给大家介绍的非常详细,对大家的学... 目录一、环境准备二、图像的基本操作1. 图像读取、显示与保存 使用OpenCV操作2. 像素级操作3.