1562

8 分钟

#C 语言标准库函数 strcat

/********************************************* * @brief 拼接字符串 * @param dest 目标字符串 * @param src 源字符串 * @return 字符串的长度 ********************************************/ char* strcat(char* restrict dest, const char* restrict src);

说明

src 指向的字符串拼接到 dest 指向的字符串之后。

注意:

  • dest 必须有足够的空间
  • destsrc 指向的字符串不可以存在重叠

参数

  • dest - 目标字符串
  • src - 源字符串
  • count - 最多复制的字节数,包括结尾的 0

返回值

  • 字符串的长度(不含结尾的 0)

#示例

#include <stdio.h> #include <string.h> #define N 16 int main(void) { char dest[N] = "hello"; strcat(dest, "world", N - strlen(dest)); // 最多复制 32 - strlen(dest) 个字符,避免越界 printf("%s\n", dest); strcat(dest, "ABCDEFGHIJKLMNOPQRSTUVWXYZ", N - strlen(dest)); // 最多复制 32 - strlen(dest) 个字符,避免越界 printf("%s\n", dest); return 0; }

说明:

  • count 设为 N - strlen(dest) 避免越界
  • "world" 拼接到 dest 时,长度未超出,正常完整拼接
  • "ABCDEFGHIJKLMNOPQRSTUVWXYZ" 拼接到 dest 超出长度 N - strlen(dest) 被截断,末尾自动设为 0

运行结果:

helloworld helloworldABCDEF

#推荐阅读

#参考标准

  • C11 standard (ISO/IEC 9899:2011):
    • 7.24.3.1 The strcat function (p: 364)
  • C99 standard (ISO/IEC 9899:1999):
    • 7.21.3.1 The strcat function (p: 327)
  • C89/C90 standard (ISO/IEC 9899:1990):
    • 4.11.3.1 The strcat function

创建于 2025/7/9

更新于 2025/8/1