提问人:Carsdan Dvorachek 提问时间:9/29/2023 更新时间:9/29/2023 访问量:42
用户在 for 循环中输入的名称在 C 中会覆盖自身
Names being entered by the user during a for loop are overwriting themselves in C
问:
我正在尝试用 C 编写一个程序,允许用户输入名称,直到他们输入单词“完成”为止。然后它将列出他们输入的所有名称。我知道我应该使用指针数组来实现此目的,然后使用 while 循环继续输入名称,然后在他们输入名称后将指针放入数组中。问题是,一旦我去打印出名字,所有的名字都等于我最后输入的任何名字。
我编写了一个更简单的程序,它做了与我正在做的事情类似的事情,并遇到了同样的问题。这是它的代码。
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
int main(void)
{
char* first;
char* second;
for (int i = 0; i < 2; i++)
{
char enteredName[20];
printf("%s", "Please enter a name: ");
scanf("%s", enteredName);
if (i == 0)
{
first = enteredName;
}
else
{
second = enteredName;
}
}
printf("First: %s\n", first);
printf("Second: %s\n", second);
}
该程序的输出为:
Please enter a name: john
Please enter a name: carl
First: carl
Second: carl
我相信正在发生的事情是,第一个和第二个变量都指向记忆中的同一个位置,所以它们只是说同样的事情。我将如何解决此问题,同时仍然使用循环输入任意数量的名称?
答:
2赞
0___________
9/29/2023
#1
我相信正在发生的事情是,第一个和第二个 变量指向内存中的同一位置,所以他们只是说 同样的事情。
是的,这是正确的。指针仅保存对象的引用(地址)。您的指针指向(引用)同一个数组。
我将如何解决此问题,同时仍然使用循环输入 任意数量的名字?
您需要将字符串复制到已分配和分配给指针的内存中
if (i == 0)
{
first = malloc(strlen(enteredName) + 1);
if(first) strcpy(first, enteredName);
}
else
{
second = malloc(strlen(enteredName) + 1);
if(second) strcpy(second, enteredName);
}
评论
0赞
Chris
9/29/2023
或者,使用 .strdup
0赞
Enno
10/1/2023
请注意,strdup 在 C23 之前不是标准的一部分,而是 POSIX 扩展。
评论
char names[N][20];
N
malloc
char *names[N];
realloc
char **names;
"john\0carl\0"