Namespaces
Variants
Views
Actions

std::memcpy

From cppreference.com
< cpp‎ | string‎ | byte
Revision as of 04:24, 5 June 2012 by Cubbi (Talk | contribs)

Template:cpp/string/byte/sidebar

Defined in header <cstring>
void* memcpy( void* dest, const void* src, std::size_t count );

Copies count bytes from the object pointed to by src to the object pointed to by dest.

If the objects overlap, the behavior is undefined. If the objects are not trivially copyable (e.g. scalars, arrays, C-compatible structs), the behavior is undefined.

Contents

Parameters

dest - pointer to the memory location to copy to
src - pointer to the memory location to copy from
count - number of bytes to copy

Return value

dest

Example

#include <iostream>
#include <cstring>
 
int main()
{
    char source[] = "once upon a midnight dreary...";
    char dest[4];
    std::memcpy(dest, source, sizeof dest);
    for (char c : dest) {
        std::cout << c << '\n';
    }
}

Output:

o
n
c
e

See also

Template:cpp/string/byte/dcl list memmoveTemplate:cpp/algorithm/dcl list copyTemplate:cpp/algorithm/dcl list copy backward
checks if a type is trivially copyable
(class template) [edit]
C documentation for memcpy