结构体或类定义中对变长成员的处理
2010-06-19 22:54
232 查看
对于一个结构体,头部信息固定,成员节点变长的,可以采用下面的定义方式:
1. 数组
typdef struct _stHeadInfo /*头部*/
{
int version;
int magic_num;
int req_count;
int res_count;
char cgiinfo[0];
} stHeadInfo __attribute__((__aligned__(4)));
typedef struct _stCgiInfo /*成员节点*/
{
int id;
int req_count;
int res_count;
int succ_num;
int fail_num;
char path[64];
} stCgiInfo __attribute__((__aligned__(4)));
这样,在初始化头信息时,可以动态分配stCgiInfo数组的大小,并把cgiinfo指向数组的头,如下所示:
#define CGINUM 100
stHeadInfo *pHeadInfo = (stHeadInfo *)malloc(sizeof(stHeadInfo) + CGINUM * sizeof(stCgiInfo));
stCgiInfo *CgiInfo = (stCgiInfo *)stHeadInfo->cgiinfo;
这样,通过下标就可以直接访问cginfo数组了,如
for (int i = 0;i < CGINUM; i++)
{
CgiInfo[id] = i;
}
此外,sizeof(stHeadInfo)的结果是不包括char cgiinfo[0]的,因为元素是0个,所以不占空间。
2.stl 容器
当然,也可以统过使用STL的容器,如vector,定义stHeadInfo如下:
typdef struct _stHeadInfo
{
int version;
int magic_num;
int req_count;
int res_count;
vector<stCgiInfo> cgiinfo;
} stHeadInfo __attribute__((__aligned__(4)));
初始化头信息时,直接resize一下,如下所示:
stHeadInfo HeadInfo;
HeadInfo.cgiinfo.resize(CGINUM);
二的优缺点比较:
前者的优点是:可以mmap到一个文件,这样,其它的进程也可以打开这个文件,解析里面的信息。同时,在做为数据包在网络上传输时,可以在headinfo中加入len字段,有清晰的边界,便于收发包。
前者的缺点是:需要管理内存分配和释放。
后者的优点是:使用简单,无需管理内存。
后者的缺点是:不便于网络传输,同时mmap到文件时,不便于预估文件大小。
1. 数组
typdef struct _stHeadInfo /*头部*/
{
int version;
int magic_num;
int req_count;
int res_count;
char cgiinfo[0];
} stHeadInfo __attribute__((__aligned__(4)));
typedef struct _stCgiInfo /*成员节点*/
{
int id;
int req_count;
int res_count;
int succ_num;
int fail_num;
char path[64];
} stCgiInfo __attribute__((__aligned__(4)));
这样,在初始化头信息时,可以动态分配stCgiInfo数组的大小,并把cgiinfo指向数组的头,如下所示:
#define CGINUM 100
stHeadInfo *pHeadInfo = (stHeadInfo *)malloc(sizeof(stHeadInfo) + CGINUM * sizeof(stCgiInfo));
stCgiInfo *CgiInfo = (stCgiInfo *)stHeadInfo->cgiinfo;
这样,通过下标就可以直接访问cginfo数组了,如
for (int i = 0;i < CGINUM; i++)
{
CgiInfo[id] = i;
}
此外,sizeof(stHeadInfo)的结果是不包括char cgiinfo[0]的,因为元素是0个,所以不占空间。
2.stl 容器
当然,也可以统过使用STL的容器,如vector,定义stHeadInfo如下:
typdef struct _stHeadInfo
{
int version;
int magic_num;
int req_count;
int res_count;
vector<stCgiInfo> cgiinfo;
} stHeadInfo __attribute__((__aligned__(4)));
初始化头信息时,直接resize一下,如下所示:
stHeadInfo HeadInfo;
HeadInfo.cgiinfo.resize(CGINUM);
二的优缺点比较:
前者的优点是:可以mmap到一个文件,这样,其它的进程也可以打开这个文件,解析里面的信息。同时,在做为数据包在网络上传输时,可以在headinfo中加入len字段,有清晰的边界,便于收发包。
前者的缺点是:需要管理内存分配和释放。
后者的优点是:使用简单,无需管理内存。
后者的缺点是:不便于网络传输,同时mmap到文件时,不便于预估文件大小。
相关文章推荐
- CodecInfo为一个结构体,包含两个成员,后面定义了这个结构体类型的一个数组
- 10.2.1 关于vc++不支持把类的成员函数定义为类的友元函数的处理
- 详解keil采用C语言模块化编程时全局变量、结构体的定义、声明以及头文件包含的处理方法!
- 8.4 Swift结构体中定义成员方法
- 详解keil采用C语言模块化编程时全局变量、结构体的定义、声明以及头文件包含的处理方法!
- 定义DNS、IP|UDP结构体,使用libpcap处理数据包
- 我在一个结构体里定义超过两个字符数组的成员输出结果会出错
- 结构体中最后一个成员数组定义0个元素的意义
- C语言中 不定义结构体变量求成员大小
- 一些可变长度对象(string对象、vector对象 ...)作为结构体或类的成员,会不会动态改变结构体或类所定义的变量的大小呢?
- C++可以这样定义结构体(为成员指定有效位数)
- C语言 结构体成员定义及使用问题
- C#如何定义结构体及访问结构体的成员
- 结构体定义无名称成员的方法
- Swift基础语法-结构体,结构体构造器,定义成员方法
- 为什么在C++使用pthread_create()的时候,类成员函数做线程的处理函数必须要定义成static类型的?
- C语言定义结构体时注意成员变量的类型和声明顺序
- 将结构体中的部分成员定义在其他文件中
- 结构体最后定义一个char p[0];这样的成员有何意义(转)
- 结构体中定义的联合成员可以直接访问!