string - 输入带空格的字符串后,scanf一直在等待输入?
问题描述
这是捕获字符串的函数:
void capture(char string[]) {
printf("_____________________________________________________________\n\n");
printf("Ingrese una cadena: ");
scanf(" %[^\n]s", string);
printf("Cadena capturada: %s\n", string);
printf("_____________________________________________________________\n\n");
}
这是在主函数中调用的函数:
void sort(char string[]) {
int opt, i, j, temp = 0;
char string_copy[50];
strcpy(string_copy, string);
for (i = 0; string_copy[i] != '\0'; i++)
for (i = 0; string_copy[i] != '\0'; i++) {
for (j = i + 1; string_copy[j] != '\0'; j++) {
if (string_copy[i] > string_copy[j]) {
temp = string_copy[i];
string_copy[i] = string_copy[j];
string_copy[j] = temp;
}
}
}
printf("_____________________________________________________________\n\n");
printf("Ordenar de modo:\n1) Ascendente\n2) Descendente\n");
printf("Seleccione una opcion: ");
fflush(stdin);
scanf(" %d", &opt);
switch(opt) {
case 1:
printf("'%s' ordenado de forma ascendente: %s\n", string, string_copy);
break;
case 2:
printf("'%s' ordenado de forma descendente: ", string);
for (i=strlen(string); i != 0; i--)
printf("%c", string_copy[i]);
printf("\n");
break;
default: printf("[ ! ] Selección incorrecta!\n"); break;
}
printf("_____________________________________________________________\n\n");
}
//Imprimir la última palabra de la cadena
void last_word(char string[50]) {
printf("_____________________________________________________________\n\n");
int i, count = 0;
for (i=0; string[i] != '\0'; i++) {
if (string[i] == ' ') {
count = i;
}
}
if (count == 0) {
printf("Solamente hay una palabra: %s\n", string);
} else {
printf("La última palabra en '%s' es: ", string);
for (i=count; string[i] != '\0'; i++) {
printf("%c", string[i]);
}
printf("\n");
}
printf("_____________________________________________________________\n\n");
}
这是有问题的代码:
int main() {
int opc = 0;
char string[50];
do {
printf("MENU:\n");
printf("1) Capturar cadena\n");
printf("2) Sustituir un caracter por otro\n");
printf("3) Buscar un caracter e imprimir el número de veces que aparece\n");
printf("4) Buscar un caracter para eliminar de la cadena.\n");
printf("5) Ordenar los caracteres alfabéticamente\n");
printf("6) Imprimir la última palabra de la cadena\n");
printf("0) Salir\n");
printf("Seleccione una opcion: ");
scanf("%i", &opc);
printf("Opcion: %d", opc);
switch(opc) {
case 1:{
capture(string);
break;
}
case 2:{
replace(string);
break;
}
case 3:{
num_char(string);
break;
}
case 4:{
delete(string);
break;
}
case 5:{
sort(string);
break;
}
case 6:{
last_word(string);
break;
}
case 0:{
printf("Bye\n");
break;
}
default: {
printf("[ ! ] Selección incorrecta!\n");
}
}
} while (opc != 0);
return 0;
}
问题在于上面的选项五在 switch 案例中:它仅在捕获的字符串没有任何空格时执行。例如,如果您输入“Hello world”。案例 5 永远不会执行并且 scanf
printf("Seleccione una opcion: ");
scanf("%i", &opc);
只会呆在那里等待输入。我重复一遍,这只会发生在捕获的字符串有空格并且您在 switch case 中选择选项5的情况下。
解决方案
capture(&string[50]);
您正在传递capture
的地址string[50]
。但是没有string[50]
。因此,您将地址传递string
到 to的末尾capture
。(因为string
有五十个条目并且0
是第一个,49
是最后一个。没有string[50]
,它超过了数组的末尾。
void capture(char string[50]) {
printf("_____________________________________________________________\n\n");
printf("Ingrese una cadena: ");
scanf(" %[^\n]s", string);
printf("Cadena capturada: %s\n", string);
printf("_____________________________________________________________\n\n");
}
哎呀,capture
写入它过去的地址string
,但这已经超过了您分配的数组的末尾。在您分配的范围之外写入内存可能会践踏其他变量并导致不可预测的结果。在您修复越界写入之前,您真的无法调试程序中的任何其他内容。您可以使用valgrind
或类似的工具来帮助检测这些类型的错误。