一个经典的结构体和联合体共用实例

描述

结构体

结构体占用的内存大小,首先和编译器的系统位数有关系,类似于CPU是 64 bits 还是 32 bits 的情形;其次,结构体需要考虑字节对齐的问题。实际上占用的内存大小, 在 Linux 中可以 使用 sizeof 进行获取,默认为字节对齐的大小。

联合体

联合体的参数共享同一个内存地址,所占的内存大小完全是由联合体中参数类型决定字长,然后数据共享,内存共享等。

结构体和联合体连用例子:1、首先定义一个结构体,内部包含联合体,如下;

 

#define MAX_SOFTKEY_LEN    4

typedef enum
{
 ENUM_TRANSFER,
 ENUM_CONFERENCE,
 ENUM_ANSWER,
 ENUM_HOLD,
}KeyType;

typedef struct tag_CallRecordInfo
{ 
 char line;                  // current recording line.
 unsigned char state;         // current machine state.
 unsigned short total;      // current total used lines.
 KeyType type;
 union
 {
  char Transferkey[MAX_SOFTKEY_LEN];     // transfer key buffer
  char Conferencekey[MAX_SOFTKEY_LEN];   // conference key buffer
  char AnswerKey[MAX_SOFTKEY_LEN];       // talking key buffer
  char HoldKey[MAX_SOFTKEY_LEN];         // hold key buffer
 }SoftKey;

}CallRecordInfo;

 

解释如下结构体:

 

联合体 union 表示公用一个 4 字节的内存,并且定义了一个联合体变量 SoftKey,这个
联合体最大的好处就是在赋值或者清空时能够直观地清楚,不需要再引用联
合体的参数。如:
CallRecordInfo info;
对 info.SoftKey 的操作会影响联合体内部参数的值,并且数值一致。也
就是说,我们只要对 info.SoftKey 进行赋值即可, 然后联合体内的参
数内容是一样的。即:
info.SoftKey = info.SoftKey.TransferKey.

 

2、结构体占用的内存大小(作者的机器为 Ubuntu 18.04, sizeof(int) = 4 的机器)

Linux

3、整体代码

 

#include 
#include 
#include 

#define MAX_SOFTKEY_LEN    4

typedef enum
{
 ENUM_TRANSFER,
 ENUM_CONFERENCE,
 ENUM_ANSWER,
 ENUM_HOLD,
}KeyType;

typedef struct tag_CallRecordInfo
{ 
 char line;                  // current recording line.
 unsigned char state;         // current machine state.
 unsigned short total;      // current total used lines.
 KeyType type;


 union
 {
  char Transferkey[MAX_SOFTKEY_LEN];     // transfer key buffer
  char Conferencekey[MAX_SOFTKEY_LEN];   // conference key buffer
  char AnswerKey[MAX_SOFTKEY_LEN];       // talking key buffer
  char HoldKey[MAX_SOFTKEY_LEN];         // hold key buffer
 }SoftKey;

}CallRecordInfo;

CallRecordInfo RecordInfo ;

void SetSoftKeyValue(int state, KeyType type, char *keybuf)
{

 RecordInfo.state = state;
 RecordInfo.type = type;
 memset(&RecordInfo.SoftKey, 0, MAX_SOFTKEY_LEN);

 if(NULL != keybuf)
 {
  memcpy(&RecordInfo.SoftKey, keybuf, MAX_SOFTKEY_LEN);
 }
}

int main(int argc, char const *argv[])
{
 
 char buf[4] = "123";

 SetSoftKeyValue(0, ENUM_TRANSFER, buf);

 printf("
%s --- %lu
", RecordInfo.SoftKey.Conferencekey, sizeof(CallRecordInfo));
 return 0;
}

 

4、结果

Linux

审核编辑:汤梓红

 

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分