我正在为一个特定的枚举数据类型构建一个验证函数。如果传递的字符串有效,验证函数将返回0 (false)或1 (true)。同时,如果字符串有效,则使用正确的条目填充枚举subType。
正如代码所示,它正确地填充了函数中的subType。我将条目打印到屏幕上进行检查。但是当我返回到main时(见下文),当我打印字符串时,我得到一个垃圾值(有时是'11871397')。
我甚至在将subType声明为const的情况下尝试过。我还有许多类似的验证函数,它们都能正确地处理引用类型,这让我相信这是枚举的问题。
int val_subscriberType (char str[], const enum ns1__subscriberType *subType )
{
if (strcmp(upStr, "PREPAID") == 0)
{
enum ns1__subscriberType subType = ns1__subscriberType__prepaid;
printf("SubscriberFunction: %d \n", subType);
return 1;
}
else if (strcmp(upStr, "POSTPAID") == 0)
{
enum ns1__subscriberType subType = ns1__subscriberType__postpaid;
printf("SubscriberFunction: %d \n", subType);
return 1;
}
return 0;
}Main
char *recRetTest = "aggressive";
enum ns1__recurrentRetrySchemaType recRet;
if ( val_recurrentRetrySchemaType (recRetTest, &recRet))
{
printf ("\nRecurrent Retry Schema main: %d \n", recRet);
}附言:我去掉了额外的代码,把字符串转换成大写,等等。
发布于 2010-11-05 23:01:13
您的主要问题是,您在if语句的分支中重新声明了subType,这隐藏了参数声明;简而言之,您将该值赋给了与参数不同的对象。
删除参数声明中的const,并将赋值重写为
if (strcmp(upStr, "PREPAID") == 0)
{
*subType = ns1__subscriberType__prepaid;
...https://stackoverflow.com/questions/4107063
复制相似问题