【问题标题】:Print array with pointer in C在C中使用指针打印数组
【发布时间】:2021-01-12 14:46:39
【问题描述】:

我有一个指向char 数组的指针,我需要打印整个数组(不是一个接一个,而是整个数组)。我有错误:zsh: segmentation fault。我不明白为什么。 我的代码从stdin 获取文本并将字符放入数组中。如果第一个数组 char_array 不够大,我将它们放在第二个名为 bigger_array 的数组中。

int main() {
    int c;
    int index = 0;
    size_t size = 100;                        
    char *char_array = malloc(size * sizeof(char)); 
    if (char_array != 0) {
        while ((c = getchar()) != EOF && index < size) {
            char_array[index] = c;
            index++;
        }
        size_t newSize = size * 100;
        char *bigger_array = realloc(char_array, newSize * sizeof(char)); 
        if (bigger_array != 0) {
            bigger_array = char_array;
            while ((c = getchar()) != EOF && index < newSize) {
                bigger_array[index] = c;
                index++;
            }
            size = newSize;
        }
    }
    printf(*char_array);
    return 0;
}

【问题讨论】:

  • 即使第一个数组有足够的输入元素,您仍在使用bigger_array
  • char_array == 0 不正确时,尝试打印char_array 指向的内容。
  • 打印出数组时,最好的办法是使用循环,但您需要查看代码,如果您将内存重新分配给新的 char 指针为什么你会有更大的数组 = 字符数组?你也没有从标准输入获取文件

标签: c dynamic printf allocation


【解决方案1】:
  • bigger_array = char_array; 应该是 char_array = bigger_array;。否则,指向新分配缓冲区的指针被覆盖为指向旧缓冲区的指针,就会发生不好的事情。
  • printf(*char_array); 不好,因为它在需要指针的地方传递一个整数(一个字符)。应该是printf("%.*s", index, char_array);。请注意,要打印的长度是指定的,因此您不需要添加终止空字符。

【讨论】:

    【解决方案2】:

    您的代码中有多个问题:

    • 您不包括&lt;stdio.h&gt; 也不包括&lt;stdlib.h&gt;
    • 您应该释放char_array 并将big_array 存储到char_array,以便char_array 指向更大的分配数组。
    • printf(*char_array) 由于多种原因具有未定义的行为。您可以使用fwrite(char_array, 1, index, stdout)printf("%.*s\n", (int)index, char_array) 打印字符。
    • 不需要单独的循环,只需按需重新分配数组即可。

    这是修改后的版本:

    #include <stdio.h>
    #include <stdlib.h>
    
    int main() {
        int c;
        size_t index = 0;
        size_t size = 100;
        char *char_array = malloc(size);
        if (char_array != NULL) {
            while ((c = getchar()) != EOF) {
                if (index == size) {
                    size_t new_size = size + size / 2 + size / 8; /* increase by the golden ratio */
                    char *new_array = realloc(char_array, new_size);
                    if (new_array == NULL) {
                        fprintf(stderr, "out of memory\n");
                        free(char_array);
                        return 1;
                    }
                    size = new_size;
                    char_array = new_array;
                }
                char_array[index++] = c;
            }
            printf("%.*s\n", (int)index, char_array);
        }
        return 0;
    }
    

    【讨论】:

      【解决方案3】:

      将此视为评论^^

      我建议您在编译器中使用 警告 标志。例如gcc 标志-W -Wextra -Wshadow 很好用,可以防止浪费时间。

      【讨论】:

        猜你喜欢
        • 2022-11-26
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2013-07-08
        • 1970-01-01
        • 2014-04-30
        • 1970-01-01
        • 1970-01-01
        相关资源
        最近更新 更多