共用体和结构体嵌套的情况最早见于NUC1XXX的库函数,后来用的非常顺手,
看下面的代码:
typedef union
{ //定义一种共用体,它包含两个成员,一个是8位的总的错误信号(错误寄存器字节1所用)
uint8_t error_sample_all;//另一个是一个结构体,结构体的每一位表示一种错误类型,
struct //由于共用体中成员共享一段内存单元,所以对error_sample_all赋值,就等于对error_sample赋值
{
uint8_t temperature:1; //NUC小端模式:最低位
uint8_t VOP:1;
uint8_t supply_28V:1;
uint8_t DISF:1;
uint8_t VSWR:1;
uint8_t nogo_synthesizer:1;
uint8_t nogo_Rx:1;
uint8_t reserved:1; //保留位
}error_sample;
}DEFINE_ERROR;
typedef是定义一种类型,具体不详述了。
定义了一种共用体,它有两个成员,一个是一个字符型变量,另一个是结构体,
结构体采用位定义,其中每一个成员占用一位,加起来刚好一个字节
DEFINE_ERROR error_register1
然后声明这样一个变量,使用效果如下:
error_register1.error_sample.DISF = 1;
为什么不用8个变量而是用一个嵌套型的结构体呢,并不是为了省内存,
而是使用的时候非常方便,例如初始化和串口传递参数时,只需要:
error_register1.error_sample_all = 0;
是不是很方便,而且由于打包在一个结构体里,非常适合寄存器的定义,便于阅读。