经常看到在结构中定一个1维的数组,估计大多数人初看这种定义都要蒙一下,其实这是用结构实现变长字符串,是程序设计中一个很有意思的技巧
使用结构实现变长字符串可以很容易的控制字符串的结构,方便对字符串数据的操作。
试想一下,如果不用结构那么需要一位一位的计算每一个字符所在位置,不把你搞死才怪
废话少说,下面是一个例子,很简单的。
#pragma pach(push, 1)
struct SHORT_STRING
{
BYTE byStrLen;
char sString[1];
};
struct STRUCT_HEAD
{
BYTE byRelation;
bool bNotify;
};
struct STRUCT_HEAD_SAVE : STRUCT_HEAD
{
SHORT_STRING PartnerName;
};
struct STRUCT_SAVE_HEAD
{
WORD wCount;
BYTE byMsgTransmit;
};
#pragma pack(pop)
#define LOGIN_ROLE_NAME_MAX_LEN 32
#define SHORT_STRING_LEN(n) ((n) + 1)
#define STRUCT_HEAD_SAVE_LEN(n) (sizeof(STRUCT_HEAD) + SHORT_STRING_LEN(n))
int main()
{
int nCount = 10;
STRUCT_SAVE_HEAD* pSaveHead;
int nSize = sizeof(STRUCT_SAVE_HEAD) + (sizeof(STRUCT_HEAD_SAVE) + LOGIN_ROLE_NAME_MAX_LEN) * nCount;
pSaveHead = (STRUCT_SAVE_HEAD*)malloc(nSize);
int nOffset = sizeof(STRUCT_SAVE_HEAD);
pSaveHead->wCount = 0;
STRUCT_HEAD_SAVE* pRelation = (STRUCT_HEAD_SAVE*)(((char*)pSaveHead) + nOffset);
static char szName[][12] = {
"1",
"22",
"333",
"4444",
"55555",
"666666",
"7777777",
"88888888",
"999999999",
"0000000000"
};
for (int i=0; i<10; i++)
{
pRelation->byRelation = 1;
pRelation->bNotify = 1;
pRelation->PartnerName.byStrLen = strlen(szName[i]);
memcpy(pRelation->PartnerName.sString, szName[i], pRelation->PartnerName.byStrLen);
nOffset += STRUCT_HEAD_SAVE_LEN(pRelation->PartnerName.byStrLen);
pRelation = (STRUCT_HEAD_SAVE*)(((BYTE*)pSaveHead) + nOffset);
pSaveHead->wCount++;
}
STRUCT_SAVE_HEAD *head = (STRUCT_SAVE_HEAD*)pSaveHead;
nOffset = sizeof(STRUCT_SAVE_HEAD);
pRelation = (STRUCT_HEAD_SAVE*)(((char*)pSaveHead) + nOffset);
pRelation = (STRUCT_HEAD_SAVE*)&(pRelation->PartnerName.sString[pRelation->PartnerName.byStrLen]);
pRelation = (STRUCT_HEAD_SAVE*)&(pRelation->PartnerName.sString[pRelation->PartnerName.byStrLen]);
pRelation = (STRUCT_HEAD_SAVE*)&(pRelation->PartnerName.sString[pRelation->PartnerName.byStrLen]);
}