Strcat,2 个字符的指针数组

Strcat, 2 char arrays of pointers

本文关键字:指针 数组 字符 Strcat      更新时间:2023-10-16

我有这样的函数,它得到 2 个数组作为 char 参数,我需要合并这个字符串。对不起,简单的问题。

    void Abc (char **a, char **b)
{
    for (int i = 0; i < 200; i++)
    {
        a[i]="hello ";
    }
    for (int i = 0; i < 200; i++)
    {
        strcat(a[i], b[i]);       //doesn't show mistake, but it's there
        cout << b[i]<<'n';        //ok
        cout << a[i]<<'n';        //ok
        cout<<strlen(b[i])<<'n';  //ok
        cout<<strlen(a[i])<<'n';  //ok
    }
}

为什么斯特卡特在这里不起作用?我能做些什么来做到这一点?

这是问题的根源:

for (int i = 0; i < 200; i++)
{
    a[i]="hello ";

编译器不知道您在此处的意图,因此a[]的每个元素都被分配了一个指向同一字符串的指针

a[0] == a[1] == a[2] == a[3] ==

a[4] == ...A[199]

即使这有效,问题也在于 now 的所有元素都指向大小为 7 的 char 数组 {'h', 'e', 'l', 'l', 'o', 0} .你不能stract到它们的末尾。

您需要确保a[]的每个元素都有一个指向唯一存储空间的指针,并且它足够大以接收您的字符串。如果您的a[]元素已经指向有效的某个位置,您需要做的是:

for (int i = 0; i < 200; i++)
{
    strcpy(a[i], "hello ");
}

首先,每个a[i]都指向字符串文字,修改它会调用未定义的行为

其次,当您strcat(x, y)时,您应该确保x有足够的空间来存储合并的xy

因此,x应该已分配内存并仔细检查,您应该使用strncat以避免意外溢出。

问题出在下面的语句中。

a[i]="hello ";

不是复制字符串文字,而是分配其地址。

改用

strcpy( a[i],"hello " );