C语言移位操作、联合体总结

article/2025/10/11 4:14:05

(1)用|置1,例如P1_flag |= 0x01;//置1 0000 0001,把bit0置1;
(2)用&置0,例如P1_flag &= 0xFE;//置0 1111 1110,把bit0置0;
(3)把一个字节对应位数据提取出来,例如light_control[0][0] = (data & 0x08)>>3;//把data指向的一字节数据保留bit3,右移3位,赋值给light_control[0][0]
(4)把一个字节对应位数据提取出来,保留赋值目标的其他位,修改对应位,例如P2_flag = P2_flag |(CANRxBuf.Data[5] & 0x04)<<1;//这种方式能置1,但是不能置0;被赋值数据一开始应该置0;
(注意:这里的P2_flag不能少
方案二:先提取对应bit判断,再手动给要赋值的bit置1或者置0;

if((CANRxBuf.Data[6] & 0x04)>>2)
{P1_flag |= 0x20;//手动置1 0010 0000
}
else P1_flag &= 0xDF;//手动置0 1101 1111

(5)两个8位数赋值到16位数;
ret = (high<<8)| low;

16位数拆分为两个8位数;
high = (ret>>8)&0xFF;
low = ret&0xFF;

(6)两个8位数组合后进行大小比较
if(((Set_H<<8)|Set_L) >= ((High<<8)|Low))

(7)两个8位数组合后进行大小比较,同时最高一位作为标志位
DataH = ((((Set_H<<8)|Set_L) - ((High<<8)|Low)) >> 8) | 0x80; //最高位置1
或者
DataH = (((Set_H<<8)|Set_L) - ((High<<8)|Low)) | 0x8000;

DataH = ((((Set_H<<8)|Set_L) - ((High<<8)|Low)) >> 8) & 0x7F; //最高位置0
或者
DataH = (((Set_H<<8)|Set_L) - ((High<<8)|Low)) | 0x7FFF;

(8)把每4bit一组数据,拼接到一个字节
for(Temp1 = 0; Temp1 < (ALL/2); Temp1++) //24表示48柜
{
Status_ALL[Temp1] = (Status[2 * Temp1] << 4) | (Status[2 * Temp1 + 1]);
}

(9)位域与联合体
位域:是指信息在存储时,并不需要占用一个完整的字节, 而只需占几个或一个二进制位。例如在存放一个开关量时,只有0和1 两种状态, 用一位二进位即可。为了节省存储空间,并使处理简便,C语言又提供了一种数据结构,称为“位域”或“位段”。所谓“位域”是把一个字节中的二进位划分为几 个不同的区域, 并说明每个区域的位数。每个域有一个域名,允许在程序中按域名进行操作。 这样就可以把几个不同的对象用一个字节的二进制位域来表示。
联合体:在进行某些算法的C语言编程的时候,需要使几种不同类型的变量存放到同一段内存单元中。也就是使用覆盖技术,几个变量互相覆盖。这种几个不同的变量共同占用一段内存的结构,在C语言中,被称作“共用体”类型结构,简称共用体,也叫联合体。
联合体位域结合起来定义数据类型:

typedef union
{u8 value;	//位域定义部分 struct  {u8  lowbit:2;u8  middlebit:3;u8  highbit:3;}byte;
}test_data;

说明:
1、value和byte共用一个字节的内存空间;
2、改变value的值,那么byte的值随着改变,同样改变byte中的位(lowbit占两位, middlebit占3位,highbit也占3位;)value的值也改变;
3、联合体这个原理,在某些场合可以替代位操作

下面以多个字节的联合体为例:

typedef union
{u8 value[2];	//位域定义部分 struct  {u8 lowbit:2;u8 middlebit:3;u8 highbit:3;u8 b1:3;u8 b2:3;u8 b3:2;}byte;
}test_data;test_data test_data_main;test_data_main.byte.lowbit=3;
test_data_main.byte.middlebit=3;
test_data_main.byte.highbit=3;
test_data_main.byte.b1 = 4;
test_data_main.byte.b2 = 4;
test_data_main.byte.b3 = 0;
SEGGER_RTT_printf(0,"lowbit = %d\r\n",test_data_main.byte.lowbit);				
SEGGER_RTT_printf(0,"middlebit = %d\r\n",test_data_main.byte.middlebit);		
SEGGER_RTT_printf(0,"highbit = %d\r\n",test_data_main.byte.highbit);		
SEGGER_RTT_printf(0,"b1 = %d\r\n",test_data_main.byte.b1);		
SEGGER_RTT_printf(0,"b2 = %d\r\n",test_data_main.byte.b2);		
SEGGER_RTT_printf(0,"b3 = %d\r\n",test_data_main.byte.b3);	
SEGGER_RTT_printf(0,"value[0] = 0x%x\r\n",test_data_main.value[0]);		
SEGGER_RTT_printf(0,"value[1] = 0x%x\r\n",test_data_main.value[1]);			

程序运行结果:
在这里插入图片描述
从中也可以看出,是低位对齐。

//20190616 更新//
位域操作问题:一般不能夸字节填充数据,需要按照组合起来8bit一个字节形式填充数据。


http://chatgpt.dhexx.cn/article/hSJsaVLR.shtml

相关文章

C语言——移位操作符

目录 左移操作符 右移操作符 算术右移 逻辑右移 总结 内存中存储的是二进制的补码。 所以移位操作符是对二进制补码进行移位。 先以左移操作符为例:<< 左移操作符 正数的情况&#xff1a; #include<stdio.h> int main() {int a10; //00000000000000000000…

【C语言】超详细的移位、位操作符详解(含力扣实战)

目录 ?1、整数的二进制表示 ?2、移位操作符 ?2.1左移操作符(低位补0) ?举例 ?原理分析 ??2.2右移操作符 ?算术右移(高位补原符号位) ?逻辑右移(高位补0) ??3、位操作符 ?3.1按位与& ?原理分析 ?3.2按位或| ?原理分析 ?3.3按位异或^ ?…

C语言的移位操作

1. C语言的移位 在C语言中&#xff0c;左移为逻辑移位&#xff0c;即左移右侧补0&#xff1b;右移为算术移位&#xff0c;即右移左侧补符号位。 上述程序对 -2 进行左移一位和右移一位的操作&#xff0c;可见-2在内存中存储为ffffffffe即11111111 11111111 11111111 1111 11…

【C语言初阶】操作符之 位运算符详解(“ << ”,“ >> ”,“ ”,“ | ”,“ ^ ”,“ ~ ”)

目录 C语言中六种位运算符&#xff1a; 一、位移运算符 1、移位运算符简介 2、先要了解一点 3、 << 左移运算符 4、>>右移运算符 5、警告 二、 1、& 按位与 2、| 按位或 3、^ 按位异或 4、~ 取反 4、例子 C语言中六种位运算符&#xff1a; &…

C语言中的移位运算

左移运算&#xff1a;对于一个位表示为的操作数 x&#xff0c;x << k 会生成一个指&#xff0c;其位表达式为。也就是说将x右边的w-k位向左移动k位&#xff0c;丢弃最高的k位&#xff0c;并在右端补k个0. 例如&#xff1a;操作数 x 位表达式为 01010101&#xff0c;x &l…

2021 华为秋招笔试题

练习: 题目描述&#xff1a; 学校有一个在线学习系统&#xff0c;没门课程由N个页面组成&#xff08;0< N< 10000&#xff09;个页面组成&#xff0c;学生从第一页开始按顺序学到最后一页提交学习记录。 系统会记录每页停留的时间&#xff08;单位秒&#xff09;&#xf…

详解2021华为笔试三道编程题

目录 2021华为笔试第一道 缓存转发数据包统计&#xff08;100%&#xff09; 解题思路&#xff1a; 参考代码&#xff1a; 2021华为笔试第二题 查找知识图谱中的实例知识&#xff08;100%&#xff09; 解题思路&#xff1a; 参考代码&#xff1a; 2021华为笔试第三题 …

笔试题(2021.7.21华为)

2021.7.21 今晚华为的面试题&#xff0c;帮同学做的&#xff0c;记录一下 说实话还挺难的&#xff0c;基本都算中等题&#xff0c;而且光看题就得看半天 链路可靠性 思路 建图&#xff0c;dfs 我这里是用的哈希表&#xff0c;加数组的形式&#xff0c;也差不多 import java.…

华为笔试AC的两道(第三道不会,我太菜)

1、猪场防疫 老李在多年前承包了一个养猪场&#xff0c; 并引入了若干只种猪&#xff0c;经过这些年的经营&#xff0c;现在养猪场有N只猪&#xff0c;编号从0到N-1 (每只猪无论生死都有唯一的编号) ; 老李在每只猪生产的时候记下了生产的母猪和出生的小猪&#xff0c;格式: x …

2021-07-08 华为2022批笔试

华为2022批笔试 三道题T1T2T3 三道题 总结&#xff1a;写的时候太紧张了&#xff0c;很烦 T1 题目&#xff1a;给出n个任务的最晚完成时间&#xff08;单位为小时&#xff09;和对应积分&#xff0c;每小时只能做一个任务&#xff0c;且超时后不获得积分&#xff0c;求出最大…

2017华为笔试、面试经历

**背景介绍**&#xff1a;2016年7月参加第十一届“华为杯”研究所电子设计大赛获西北赛区一等奖&#xff0c;于2016年8月到上海嘉定工业区参加全国总决赛获全国三等奖。 期间&#xff0c;参加了在线测评、笔试、专业面试、综合面试、部门选择、未完待续。 **备注**&#xff1a;…

4.15日华为笔试

参考&#xff1a; 华为笔试&#xff0c;大家做的怎么样&#xff1f;华为4.15笔试前两题AC - 正则表达式华为笔试2.7 4-15 - C华为4.15笔试 - C 题目简介&#xff1a; 第一题&#xff1a;求获胜者&#xff0c;如果票数相当&#xff0c;按照字母排序&#xff0c;a>b>c,A…

19.华为笔试题整理

1.两数之和 数组可以有重复元素,所以与力扣的第一题稍微有点不同 public int[] twoSum(int[] numbers, int target) {int n numbers.length;HashMap<Integer, Integer> map new HashMap<>();for (int i 0; i < n; i) {int realTarget target - numbers[i];i…

华为2020校招笔试编程题

华为2020校招笔试编程题 刚做完华为的笔试题&#xff0c;简要描述一下三道编程题的解决方法以及python代码实现 第一题大致描述&#xff1a; 给定两个已经升序排序好的的序列A{a1,a2,a3,...an} 和B{b1,b2,b3...bn} &#xff0c;一个数R&#xff0c;找出满足以下条件的的&#x…

华为笔试题 2022.3.30

1、业务部署芯片 思路&#xff0c;就硬模拟 #include <algorithm> #include <iostream> #include <string> #include <vector>using namespace std;int main() {int m, n;cin >> m;cin >> n;char arr[n];for (int i 0; i < n; i) {ci…

华为2019届校招笔试题

1. 给出一个字符串&#xff0c;将重复的字符去除&#xff0c;仅保留第一次出现的字符&#xff0c;且保持去重后的字符在原字符串中的顺序不变。 输入数据是一个字符串&#xff08;不包含空格&#xff09; 输出去重后的字符串 输入&#xff1a;12ere2 输出&#xff1a;12er…

【JAVA】【华为校园招聘笔试-软件】2020-09-09

前言 华为三道题&#xff0c;100200300&#xff0c;100及格&#xff0c;大家做对第一题就好了&#xff0c;祝大家全都有心仪的offer&#xff0c;不要慌&#xff0c;不要焦虑 一、完美排列——玩具&#xff08;全A&#xff09;&#xff08;注意&#xff1a;题目中说&#xff…

华为2020届逻辑笔试

1、十进制46.25对应的二进制表达式为( )。 A 101110.11 B 101101.01 C 101110.1 D 101110.01 解析&#xff1a; 首先这个题目是由整数部分和小数不同共同组成的&#xff0c;整数部分的计算是最简单的&#xff0c;整数部分除以2得到的余数按照逆向顺序排列后就是整数部分转化为二…

华为笔试

目录 2017年4月21日华为笔试题 圣诞的祝福 2017年4月21日华为笔试题 德州扑克 2017年4月21日华为笔试题 日期的天数序号 2017华为笔试题 任务调度 2017华为笔试题 公司年会 2017华为笔试题 水仙花数 2018华为笔试题 2018华为笔试题2 2017年4月21日华为笔试题 圣诞的祝福…

1.华为实习笔试

第一题(100分) 版本号排序问题,比如1.1.1版本大于1.0.0版本,每个.分割的数字范围是0-256,可以省略,比如..等价于0.0.0,可以有前导0,比如001.001.1等价于1.1.1;程序输入:需要排序的版本号个数,和各个版本号字符串,输出排序后的结果 public static List<String> dealSpli…