I wish to copy content of specific length from one buffer to another from a specific starting point. I checked memcpy()
but it takes only the length of content
Just add the offset to the addresses. For example, if you wanted to copy the buffer starting with the Nth byte:
memcpy( destination, source + N, sourceLen - N );
This will copy to the destination
. If you also want to offset the destination - add the offset to both:
memcpy( destination + N, source + N, sourceLen - N );
An index is not required because you can simply update the source pointer by the specified number of bytes. The following wrapper should do the trick
void* memcpy_index(void *s1, const void *s2, size_t index, size_t n) {
s2 = ((char*)s2)+index;
return memcpy(s1, s2,n);
}
This site needs a way to allow anonymous followups in addition to anonymous answers.
Why, more than once, do I see this insane assertion that an "index" must be in units of 1 byte? It's the complete opposite of convention. An "index" is usually symbolic, a measure whose physical byte offset is determined by the size of the element in the array (or vector, which may not even have the physical layout of an array, but then memcpy() is irrelevant too of course).
So, the 5th element in an array has "index" 5, but:
Which way is the correct way to access that specific element is a side point. The important part is that you understand the difference, choose one, and make the code correct.
On the meaning of words, I would much rather read:
void* memcpy_offset(void *s1, const void *s2, size_t offset, size_t n);
than:
void* memcpy_index(void *s1, const void *s2, size_t index, size_t n);
I find the idea that a completely generic void * could have an "index" to be misleading. (While we're here, "dest" and "source" or "in" and "out" would be much less ambiguous than "s1" and "s2". Code doesn't need as many comments when you pick self-explanatory variable names.)
If you're using c++, it is probably better to use std::copy() instead of memcpy(). std::copy can take pointers just as easily as iterators.
e.g.
int src[20];
int dst[15];
// Copy last 10 elements of src[] to first 10 elements of dst[]
std::copy( src+10, src+20, dst );
As with memcpy(), it's your responsibility to make sure the pointers are valid.
NOTE. If your usage is performance critical you may find a memcpy() as detailed in the other answers quicker, but probably not by much.
Simply increase your pointer to your start index.
Example
const unsigned char * src = reinterpret_cast<const unsigned char*>(your source);
unsigned char * dest = reinterpret_cast<unsigned char *>(your dest);
memcpy(dest, src + offset, len);
What about using STL collections to avoid memory access errors?
Simply add the index to the address of the buffer, and pass it to memcpy()
as the source parameter, e.g. copy from 3rd item of buffer b
char a[10], b[20];
::memcpy(a,b+2,10);
Also take into account the type of items in the buffer, length (3rd) parameter of memcpy() is in bytes, so to copy 4 ints you shall put 4*sizeof(int) - which will probably be 16 (on a 32 bit system. But the type does not matter for the start address, because of pointer arithmetics:
int a[10], b[10];
::memcpy( a+2, b, 2*sizeof(int) );
// a+2 will be address of 3rd item in buffer a
// not address of 1st item + 2 bytes