NUC140 之共用体和结构体嵌套

 共用体和结构体嵌套的情况最早见于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;	

是不是很方便,而且由于打包在一个结构体里,非常适合寄存器的定义,便于阅读。

猜你喜欢

转载自blog.csdn.net/pxy198831/article/details/85564163