strcat — concatenate two strings
#include <string.h>
char *strcat(char *restrict s1, const char *restrict s2);
[CX] The functionality described on this reference page is aligned with the ISO C standard. Any conflict between the requirements described here and the ISO C standard is unintentional. This volume of POSIX.1-2024 defers to the ISO C standard.The strcat() function shall append a copy of the string pointed to by s2 (including the terminating NUL character) to the end of the string pointed to by s1. The initial byte of s2 overwrites the NUL character at the end of s1. If copying takes place between objects that overlap, the behavior is undefined.
[CX] The strcat() function shall not change the setting of errno on valid input.
The strcat() function shall return s1; no return value is reserved to indicate an error.
No errors are defined.
None.
This version is aligned with the ISO C standard; this does not affect compatibility with XPG3 applications. Reliable error detection by this function was never guaranteed.
None.
None.
XBD <string.h>
First released in Issue 1. Derived from Issue 1 of the SVID.
The strcat() prototype is updated for alignment with the ISO/IEC 9899:1999 standard.
Austin Group Defect 448 is applied, adding a requirement that strcat() does not change the setting of errno on valid input.
return to top of page