您好我已经编写了一个基于需求的代码。C代码 - 需要澄清的有效性
(field1_6)(field2_30)(field3_16)(field4_16)(field5_1)(field6_6)(field7_2)(field8_1) ..... 这是一个斗式(8场)数据的。我们将一次收到20个桶,共计160个字段。 我需要根据预定义的条件取field3,field7 & fields8的值。 如果输入参数是N,则从第一个桶取三个字段,如果是Y,我需要 从除第一个桶以外的任何其他桶取得三个字段。 如果argumnet是Y,那么我需要一个接一个地扫描所有20个桶并检查 桶的第一个字段不等于0,如果它是true,则获取该桶的三个字段并退出。 我已经写了代码,它也工作得很好..但不那么自信,它是有效的。 我恐怕有一段时间会崩溃。请在下面提示是代码。
int CMI9_auxc_parse_balance_info(char *i_balance_info,char *i_use_balance_ind,char *o_balance,char *o_balance_change,char *o_balance_sign
)
{
char *pch = NULL;
char *balance_id[MAX_BUCKETS] = {NULL};
char balance_info[BALANCE_INFO_FIELD_MAX_LENTH] = {0};
char *str[160] = {NULL};
int i=0,j=0,b_id=0,b_ind=0,bc_ind=0,bs_ind=0,rc;
int total_bukets ;
memset(balance_info,' ',BALANCE_INFO_FIELD_MAX_LENTH);
memcpy(balance_info,i_balance_info,BALANCE_INFO_FIELD_MAX_LENTH);
//balance_info[BALANCE_INFO_FIELD_MAX_LENTH]='\0';
pch = strtok (balance_info,"*");
while (pch != NULL && i < 160)
{
str[i]=(char*)malloc(strlen(pch) + 1);
strcpy(str[i],pch);
pch = strtok (NULL, "*");
i++;
}
total_bukets = i/8 ;
for (j=0;str[b_id]!=NULL,j<total_bukets;j++)
{
balance_id[j]=str[b_id];
b_id=b_id+8;
}
if (!memcmp(i_use_balance_ind,"Y",1))
{
if (atoi(balance_id[0])==1)
{
memcpy(o_balance,str[2],16);
memcpy(o_balance_change,str[3],16);
memcpy(o_balance_sign,str[7],1);
for(i=0;i<160;i++)
free(str[i]);
return 1;
}
else
{
for(i=0;i<160;i++)
free(str[i]);
return 0;
}
}
else if (!memcmp(i_use_balance_ind,"N",1))
{
for (j=1;balance_id[j]!=NULL,j<MAX_BUCKETS;j++)
{
b_ind=(j*8)+2;
bc_ind=(j*8)+3;
bs_ind=(j*8)+7;
if (atoi(balance_id[j])!=1 && atoi(str[bc_ind])!=0)
{
memcpy(o_balance,str[b_ind],16);
memcpy(o_balance_change,str[bc_ind],16);
memcpy(o_balance_sign,str[bs_ind],1);
for(i=0;i<160;i++)
free(str[i]);
return 1;
}
}
for(i=0;i<160;i++)
free(str[i]);
return 0;
}
for(i=0;i<160;i++)
free(str[i]);
return 0;
}
@ DGNA,第一件事情是我有一个确认,我将永远不会收到少于8场INA单斗。唯一的事情是它可以acse我可能不会收到20桶有时times.condcond balnace信息将永远不会为null。因为我通过它后,检查其不为空的其他函数 – Vijay 2009-10-09 09:53:31
代码的性质是,它得到了重用新的背景下,并根据新的假设。防御性编码可以保护您免受调用您的东西中的变化(和错误)。如果您关心性能开销,那么使用ASSERT(),它可以在开发过程中使用并编译生成 – djna 2009-10-09 11:36:02