获取输入到动态分配的内存然后返回指针

时间:2015-05-16 22:46:25

标签: c arrays pointers malloc

嘿,伙计们,我一直在解决这个问题。我已经尝试了很多方法,从使用stdin循环并将每个字母保存到scanf("%s")到一个数组然后将数组声明为指针然后返回指针。我已经接近了,但是当我输入的字符串中有空格时,主要有问题。程序需要调用此char *获取指向字符串的指针,两次,然后逐行输出两个字符串。非常感谢任何帮助。

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因为在工作,我的程序在家里。任何想法请

1 个答案:

答案 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; } 或变量,否则任何输入方法都会受到此限制。请考虑将最大长度传递给输入函数,或确保验证退货)

您还可以使用#definegetchar()阅读逐个字符,或者使用行输入方法,例如{{ 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;
}