memcpy — copy bytes in memory
#include <string.h>
void *memcpy(void *restrict s1, const void *restrict s2, size_t n);
[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 memcpy() function shall copy n bytes from the object pointed to by s2 into the object pointed to by s1. If copying takes place between objects that overlap, the behavior is undefined.
[CX] The memcpy() function shall not change the setting of errno on valid input.
The memcpy() function shall return s1; no return value is reserved to indicate an error.
No errors are defined.
None.
The memcpy() function does not check for the overflow of the receiving memory area.
None.
None.
XBD <string.h>
First released in Issue 1. Derived from Issue 1 of the SVID.
The memcpy() prototype is updated for alignment with the ISO/IEC 9899:1999 standard.
Austin Group Defect 448 is applied, adding a requirement that memcpy() does not change the setting of errno on valid input.
return to top of page