在C中连接两个字符串并将结果放入第三个字符串

时间:2013-10-24 17:04:20

标签: c

这纯粹是出于自身利益而不是家庭作业。

#include <stdio.h>

int main(void)
{
    char* str3;

    char* str1 = "Hello";
    char* str2 = "World!";

    while(*str1) str1++;
    while(*str1++ = *str2++);

    return 0;
}

我正在尝试更好地理解C指针,并且这样做我想连接两个字符串并将结果放入第三个字符串。上面的(不完整的)代码导致了段错误,我不知道为什么。是不是可以循环指针引用的值并将数据复制到另一个地址?

编辑:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

int main(void)
{
    char* str1 = "Hello";
    char* str2 = "World!";

    char *str3 = malloc(strlen(str1) + strlen(str2) + 1);

    while(*str1) *str3++ = *str1++;
    while(*str2) *str3++ = *str2++;

    puts(str3);

    return 0;
}

新的尝试是在上面,虽然不起作用,但是我需要修复“明显”的项目吗?

5 个答案:

答案 0 :(得分:6)

    while(*str1) str1++;

这会使str1前进,直到它指向字符串常量末尾的终止零字节。

    while(*str1 = *str2++);

这会修改字符串末尾的终止零字节,但字符串是常量,因此无法修改。

如果要在内存中组合字符串,则需要分配一些空间来执行此操作或使用这样做的函数。你可以这样做:

char *new_string = malloc(strlen(str1) + strlen(str2) + 1);
strcpy(new_string, str1);
strcat(new_string, str2);

第一行分配足够的空间来保存str1的内容,str2的内容和终止的零字节。

答案 1 :(得分:1)

  int main(void)
  {
      char* str1 = "Hello";
      char* str2 = "World!";
      // allocate one more byte for string terminate cher ('\n')
      int size = strlen(str1) + strlen(str2);
      char* str3 = (char*)malloc(size + 1);
      char* str_mod = str3;

      while( (*str_mod++ = *str1++) != '\0');
      str_mod--;
      while( (*str_mod++ = *str2++) != '\0');

      printf ( "%s", str3);
      free (str3);

      return 0;
  }

答案 2 :(得分:0)

常量字符串不可修改。你没有修改str3。 你需要

  1. 获取str1和str2的长度。
  2. malloc长度str1 +长度str2 + 1并分配给str3
  3. 如果您喜欢复制,可以使用while循环,或者可以使用strcpy和strcat将字符串复制到str3。
  4. 由于您正在努力学习,我正在努力不为您编写代码。

答案 3 :(得分:0)

int main (void){
    char* str1 = "Hello";
    char* str2 = "World";

    int size1 = strlen(str1);
    int size2 = strlen(str2);
    int i = 0;

    char* out = malloc(sizeof(char)*(size1+size2)+1);

    for (i = 0; i < size1; i++){
        out[i] = str1[i];
    }
    for (i = 0; i < size2; i++){
        out[i+size1] = str2[i];
    }
    out[strlen(out)-1] = \0;
    //out is a string.
    //dont forget to free when you are done.  free(out);

}

自从我做了C以来已经过了几个月,但这样可行。我的语法可能略有偏差。

答案 4 :(得分:0)

有问题的第二次尝试错过了将字符串终止null置于str3的末尾。所以puts读取超出数据的结尾,打印垃圾,如果在读取无效地址之前没有0字节,甚至可能会崩溃。循环后添加*str3 ='\0';

此外,您修改str3并失去字符串的开头。再添加一个变量,保留malloc返回的指针,并将其传递给puts。当前代码将在新字符串的末尾开始打印。

然后当你有指向字符串文字的指针时,使它们指向const char,因为通常字符串文字在只读存储区中:

const char* str1 = "Hello";
const char* str2 = "World!";