既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
常用的位域格式如下:
typedef union {
unsigned char temp;
struct {
unsigned char t1:1;
unsigned char t2:2;
unsigned char t3:4;
unsigned char t4:1;
}bitField;
}Test;
我们在一个字节里,按位进行了编码。
那么就出现了一个问题,位域中的第一个元素t1是对应一个字节里的低位(LSB)还是高位(MSB)。
下面我们用一段代码来测试一下:
#include <stdio.h>
typedef union {
unsigned char temp;
struct {
unsigned char t1:1;
unsigned char t2:2;
unsigned char t3:4;
unsigned char t4:1;
}bitField;
}Test;
int main() {
Test test;
test.temp = 0b11011010;
printf("t1 = %d\n",test.bitField.t1);
printf("t2 = %d\n",test.bitField.t2);
printf("t3 = %d\n",test.bitField.t3);
printf("t4 = %d\n",test.bitField.t4);
}
简单一看,我们知道t1是对应一个字节里的低位(LSB),t4对应的是一个字节里的高位(MSB)。
我们继续在VxWorks上的虚拟目标机上进行了测试,测试结果如下图
下面我们用一张图来说明这个问题
这个位域的例子是总共只占用了一个字节,如果占用不止一个字节呢?情况会怎样?位域元素是否可以跨字节存在呢?
#include <stdio.h>
typedef union {
unsigned int temp;
struct {
unsigned char t1:1;
unsigned char t2:6;
unsigned char t3:3;
unsigned char t4:4;
unsigned char t5:4;
unsigned char t6:6;
unsigned char t7:8;
}bitField;
}Test;
int main() {
Test test;
test.temp = 0b11001010010101011100110111011010;
printf("t1 = %d\n",test.bitField.t1);
printf("t2 = %d\n",test.bitField.t2);
printf("t3 = %d\n",test.bitField.t3);
printf("t4 = %d\n",test.bitField.t4);
printf("t5 = %d\n",test.bitField.t5);
printf("t6 = %d\n",test.bitField.t6);
printf("t7 = %d\n",test.bitField.t7);
}
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**