程序如下
void EnterMember(Member Memb[100])
{
int i;
int len = 0;
int cflag1=0;
char cflag2 = ' ';
while (1)
{
EMbgn: printf("\n请输入要录入简历的编号(3位):");
scanf_s("%s", &Memb[counts].num,4);
len = strlen(Memb[counts].num);
cflag1 = 0;
for (i = 1; i <=counts; i++) //循环判断简历是否已经存在
{
if (strcmp(Memb[counts].num, Memb[i].num) == 0)
{
printf("该简历已存在!请重新输入");
cflag1 = 1;
break;
}
}
if (cflag1 == 1)
{
goto EMbgn; //如果简历已经存在则继续循环第一步
}
else if (len == 3) //如果一切正常则开始录入简历
{
break;
}
else
{
printf("输入有误!请选择是否继续录入(Y/N)?\n");
scanf_s("%c", &cflag2,1);
switch (cflag2)
{
case 'Y': goto EMbgn;break;
case 'N': return;
}
}
}
printf("\n请输入要录入该简历的姓名:");
scanf_s("%s", Memb[counts].name,10);
printf("\n请输入要录入该简历的成员的性别:");
scanf_s("%s", Memb[counts].sex,4);
printf("\n请输入要录入该简历的成员的年龄:");
scanf_s("%s", Memb[counts].age,5);
printf("\n请输入要录入该简历的成员的出生年月:");
scanf_s("%s", Memb[counts].date,20);
printf("\n请输入要录入该简历的成员的民族:");
scanf_s("%s", Memb[counts].nality,9);
printf("\n请输入要录入该简历的成员的健康状况:");
scanf_s("%s", Memb[counts].health,6);
printf("\n请输入要录入该简历的成员的电话号码:");
scanf_s("%s", Memb[counts].tel,20);
printf("\n请输入要录入该简历的成员的邮箱地址:");
scanf_s("%s", Memb[counts].mail,30);
printf("\n请输入要录入该简历的成员的联系地址:");
scanf_s("%s", Memb[counts].address,50);
printf("\n请输入要录入该简历的成员的毕业学校:");
scanf_s("%s", &Memb[counts].school,30);
printf("\n请输入要录入该简历的成员的就读专业:");
scanf_s("%s", Memb[counts].major,30);
printf("\n请输入要录入该简历的成员的四级英语成绩:");
scanf_s("%s", Memb[counts].Elgrade,6);
printf("简历信息已经录入系统!\n");
counts++;
fflush(stdin); //清除缓冲区的内容
}
每次运行到需要重新输入编号的时候就自动跳过scanf_s函数自动回到EMbgn语句。为什么呢?
printf("输入有误!请选择是否继续录入(Y/N)?\n");
scanf_s("%c", &cflag2,1);
switch (cflag2)
{
case 'Y': goto EMbgn;break;
case 'N': return;
}
运行如图
经过各种贴吧百度之后,总算是明白了。这是一个scanf函数陷阱,一般来讲我们都是用回车来结束scanf函数,这样的话\n这个符号就会留在缓冲区,下一次碰到scanf函数就会直接读取留在缓存区的\n符号而不是等待输入。
尽管我在scanf_s函数上下行都加了fflush()函数也没有用。经过实验,解决办法有两种:
其一,每次结束scanf_s函数时用“CTRL+Z”来结束;
其二,在每一个scanf_s(“%c,”)中的%c前加一个空格来抵消“\n”字符;