char* get_input()
{
char c = 'a';
int counter = 1;
while(c != '\0')
{
c = getc(stdin);
char* d = (char)malloc(sizeof(char)*counter);
*(d+counter) = c;
counter++;
return d;
}
return d;
}
所以我认为这样的事情是最好的方法,但我不知道如何将指针从while循环中返回,然后再返回char *。我真正需要的是关于将一些输入直接存储到已分配的数组中的最佳方法的一些指导,这些数据不会浪费任何内存(它会知道你输入的字符串有多长并且分配了足够的内存)我也尝试过scanf(& #34;%s")但我不知道如何将scanf中的数据存入动态内存块。
很遗憾没有我的实际代码atm因为在工作,我的程序在家里。任何想法请
答案 0 :(得分:2)
您之前的代码:
char* get_input()
{
char c = 'a';
int counter = 1;
while(c != '\0')
{
c = getc(stdin);
char* d = (char)malloc(sizeof(char)*counter);
*(d+counter) = c;
counter++;
return d;
}
return d;
}
哦,不,不,不!您创建一个单独的指针地址,指向counter
大小的内存块,每次调用malloc
,将其分配给d
,然后尝试将c
分配给{{ 1}}写入超出当前块的末尾,并且绝对无法知道前一次迭代中*(d+counter)
是什么 - 叹息......
首先,有很多方法可以进行动态输入,因为彩虹中有颜色...它可以像使用带有d
转换说明符的scanf
一样简单无知(旧版本)和windows使用%m
)。它伴随着%a
带来的所有陷阱。但是,它可以工作:
scanf
但绝对没有限制数据输入和控制。 (注意:除非您将其他信息传递给任何输入函数或使用全局char *get_input_scanf()
{
char *ln = NULL;
scanf ("%m[^\n]%*c", &ln);
return ln;
}
或变量,否则任何输入方法都会受到此限制。请考虑将最大长度传递给输入函数,或确保验证退货)
您还可以使用#define
或getchar()
阅读逐个字符,或者使用行输入方法,例如{{ 1}}或getc(fp)
。使用这些方法中的任何一个(fgets
除外),您将需要分配一个临时行缓冲区来保存输入,然后为了限制分配到所需的数量,根据{{1分配最终缓冲区您的输入(或使用getline
)。与所有动态方法一样,您负责跟踪它,保留内存块的起始地址,并在不再需要时释放内存。除此之外,天空是你对这个功能的限制。
getline
的动态输入例程示例如下所示:
strlen + 1
注意:如上所述,strdup
对输入字符串的长度没有限制,因此需要您进行验证。
动态输入的不同方式数量没有限制。 (这里SO上可能至少有1000个例子)但是,这一切都归结为字符或行输入,所以请选择你想要的方法使用然后编写代码。这是一个小工作示例,具有上述两个不同的功能。查看帖子,如果您有任何疑问,请告诉我。
getline
示例使用/输出
char *get_input()
{
char *ln = NULL; /* line buffer, NULL - getline allocates */
size_t n = 0; /* initial buff size, 0 - getline decides */
ssize_t nchr = 0; /* getline return - actual no. of chars read*/
if ((nchr = getline (&ln, &n, stdin)) != -1)
{
/* strip newline or carriage rtn */
while (nchr > 0 && (ln[nchr-1] == '\n' || ln[nchr-1] == '\r'))
ln[--nchr] = 0;
/* if (!nchr) { // do not accept blank lines
free (ln);
return NULL;
} */
char *input = strdup (ln); /* duplicate ln in input */
free (ln); /* free getline allocated mem */
return input;
}
return NULL;
}