C++ memcpy()

The memcpy() function in C++ copies specified bytes of data from the source to the destination. It is defined in the cstring header file.

Example

#include <cstring>
#include <iostream>
using namespace std;

int main() {
  char source[] = "Tutorial";
  char destination[] = "codemy";

// copy all bytes of source to destination memcpy(destination, source, sizeof(source));
cout << destination; return 0; } // Output: Tutorial

memcpy() Syntax

The syntax of the memcpy() function is:

memcpy(void* dest, const void* src, size_t count);

memcpy() Parameters

The memcpy() function accepts the following parameters:

  • dest - pointer to the memory location where the contents are copied to. It is of void* type.
  • src - pointer to the memory location where the contents are copied from. It is of void* type.
  • count - number of bytes to copy from src to dest. It is of size_t type.

Note: Since src and dest are of void* type, we can use most data types with memcpy().


memcpy() Return Value

The memcpy() function returns:

  • dest - the memory location of the destination

memcpy() Prototype

The prototype of memcpy() as defined in the cstring header file is:

void* memcpy(void* dest, const void* src,size_t count);

When we call this function, it copies count bytes from the memory location pointed to by src to the memory location pointed to by dest.


memcpy() Undefined Behavior

The behaviour of memcpy() is undefined if:

  • either src or dest is a null pointer, or
  • the objects overlap.

Example 1: C++ memcpy()

#include <cstring>
#include <iostream>
using namespace std;

int main() {
  char source[] = "Tutorial";
  char destination[] = "codemy";

  cout << "Initial destination: " << destination << endl;

// copy all bytes of destination to source memcpy(destination, source, sizeof(source));
cout << "Final destination: " << destination; return 0; }

Output

Initial destination: codemy
Final destination: Tutorial

Here, we have copied all the bytes of source to destination using the sizeof() function.


Example 2: C++ memcpy() - Copy Only Parts of source

#include <cstring>
#include <iostream>
using namespace std;

int main() {
  char source[] = "Tutorial";
  char destination[] = "codemy";

  cout << "Initial destination: " << destination << endl;

// copy 4 bytes of destination to source memcpy(destination, source, 4);
cout << "Final destination: " << destination; return 0; }

Output

Initial destination: codemy
Final destination: Tutoramiz

Here, we have only copied 4 bytes of source to destination.

Since a single char data occupies 1 byte, this program replaces the first 4 characters of destination with the first 4 characters of source.


Example 3: C++ memcpy() with Integer Type

#include <cstring>
#include <iostream>
using namespace std;

int main() {
  int source[10] = {8,3,11,61,-22,7,-6,2,13,47};
  int destination[5];

// copy 5 elements (20 bytes) of source to destination memcpy(destination, source, sizeof(int) * 5);
cout << "After copying" << endl; for (int i=0; i<5; i++) cout << destination[i] << endl; return 0; }

Output

After copying
8
3
11
61
-22

Here, we have created two int arrays source[] and destination[] of sizes 10 and 5 respectively.

We have then used the memcpy() function to copy 5 elements of source[] to destination[].

memcpy(destination, source, sizeof(int) * 5);

Notice the argument sizeof(int) * 5. The code sizeof(int) gives the total bytes occupied by a single int data i.e. 4 bytes.

Since we want to copy 5 int elements from source[] to destination[], we multiply sizeof(int) by 5, which equals to 20 bytes of data.