更改 char[] 数组的元素

Changing an element of an array of char[]

我发现C语言中的字符串或字符数组令人困惑,因此我在编写代码时容易犯错误和错误。下面的代码接受一个字符数组,并在打印时将第四个元素打印为 x.

void printString(char stuff[]) {
    for (int i = 0; i < 5; i++) {
        if (i == 3) {
            stuff[i] = 'x';
        }
        printf("%c", stuff[i]);
    }
}

int main(void) {
    char z[] = "hello";
    printString(z); // output helxo

尝试对字符数组应用相同的概念时,您无法更改值

void printStrings(char stuff[5][20]) {
    for (int i = 0; i < 5; i++) {
        if (i == 4) {
            stuff[i] = "Not Cool"; // Error: assignment to expression with array type
        }
        printf("%s\n", stuff[i]);
    }
}

int main(void) {
    char a[5][20] = {
        "Words",
        "More Words",
        "Letters",
        "Arrays",
        "Cool"
    }
}

如有任何帮助,我们将不胜感激。

P.S。任何指向解释字符数组和字符串的资源的链接也会有所帮助:)

When trying to apply the same concept with an array of character arrays, you can't change the values

是的,你可以,只是不是你这样做的方式。您不能将一个数组 分配 给另一个数组。但是您可以使用 strcpy() 代替 copy 个字符从一个数组到另一个数组,例如:

strcpy(stuff[i], "Not Cool");

或更好,strncpy(),例如:

strncpy(stuff[i], "Not Cool", 20);

When trying to apply the same concept with an array of character arrays, you can't change the values

问题不在于您不能更改这些值。正如编译器告诉您的那样:您不能分配给整个数组。

鉴于此声明:

void printStrings(char stuff[5][20]) {

参数stuff是一个指向20char数组的指针。 stuff[4] 因此指定一个数组,而不是左值——您不能分配给它。但是你可以通过赋值修改它的元素,或者更一般地说,你可以通过适当的函数修改它的内容,比如strcpy().

    stuff[4][0] = 'f';

I find strings or character arrays in C confusing

关于 C 字符串有一些令人困惑的事情,但我希望能帮助您的一件事是认识到字符串和字符数组不是一回事。字符串是可以由字符数组的 contents 表示的值。即使当一个字符数组包含一个字符串(因为它的任何一个或多个元素的值为 '\0' 并因此用作字符串终止符)时,数组本身也不是字符串,即使我们有时对我们的语言有点松懈围绕这样的事情。

考虑到字符串文字有其自身的怪癖,而数组通常也有怪癖,是的,有很多混淆的空间。

= 运算符未定义为将一个数组的内容复制到另一个数组。您要么必须在循环中单独复制每个数组元素:

for ( size_t i = 0; i < num_elements; i++ )
  dst[i] = src[i];

或者你必须调用像 strcpy(对于包含字符串的数组)或 memcpy(对于不包含字符串的数组)这样的库函数,它们的作用几乎相同在幕后。

structunion 等其他聚合类型相比,C 中的数组和数组表达式很奇怪;作为这种怪异的一部分,数组表达式不允许成为赋值运算符的目标。在大多数情况下,类型为“T 的数组”的表达式被转换或“衰减”为类型为“指向 T 的指针”的表达式,并且表达式的值是数组的地址数组的第一个元素。

这不是任意的——Ritchie 有理由让数组以这种方式运行——但这并没有让它变得不那么奇怪。

您的误解来自于您认为数组和其他对象一样是可赋值的。数组的C概念有点差。当你将数组标识符作为一个整体使用时,你并不是指整个数组,而是它的第一个元素的(常量)地址(就像指针一样),所以你不能写这样的东西:

char A[100], B[100];
A = B; /* error, A is a constant address (the address of A array) and B is a constant address, so A is not assignable. */

这在将数组作为参数传递给函数时非常有效,因为它避免了将整个数组复制到参数列表中,而只是将一个指针放入其中。它还解放了最初的 C 实现者,让他们可以在分配数组时编写代码来复制完整的内存块(这在编程中很少使用)

为了提供解决方案,他们编写了一系列函数,允许您复制数组或字符串(它们是 char 的数组)。您可以使用:

#include <string.h>
...
       strcpy(stuff[i], "Not cool");

这将使字符串文字被复制到 i-esim 数组元素的位置。

你说过

When trying to apply the same concept with an array of character arrays, you can't change the values

但是在第一种情况下,当您切换到数组时,您分配了一个 char 对象(作为标量值在 C 中是可分配的),您发现整个数组不可分配在 C.