memcpy 百度百科
void *memcpy(void *dest, const void *src, size_t n);
1函数原型
void *memcpy(void *dest, const void *src, size_t n);
2功能
从源src所指的内存地址的起始位置开始拷贝n个字节到目标dest所指的内存地址的起始位置中
3所需头文件
C语言中使用#include <string.h>;
C++中使用#include <cstring>; [cstring是C++在移植C的头文件时前面会加字母'c' ]
4返回值
函数返回dest的值。
5说明
1.source和destin所指的内存区域可以重叠,但是如果source和destin所指的内存区域重叠,那么这个函数并不能够确保source所在重叠区域在拷贝之前被覆盖。而使用memmove可以用来处理重叠区域。函数返回指向destin的
指针。
2.strcpy和memcpy主要有以下3方面的区别。
2.2、复制的方法不同。strcpy不需要指定长度,它遇到被复制字符的串结束符"\0"才结束,所以容易溢出。memcpy则是根据其第3个参数决定复制的长度。
2.3、用途不同。通常在复制字符串时用strcpy,而需要复制其他类型数据时则一般用memcpy
3.如果目标数组destin本身已有数据,执行memcpy()后,将覆盖原有数据(最多覆盖n)。如果要追加数据,则每次执行memcpy后,要将目标数组地址增加到你要追加数据的地址。
注意:source和destin都不一定是数组,任意的可读写的空间均可。
6函数实现
微软中:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
void
* __cdecl
memcpy
(
void
* dst,
const
void
* src,
size_t
count
)
{
void
* ret = dst;
#if defined (_M_MRX000) || defined (_M_ALPHA) || defined (_M_PPC)
{
extern
void
RtlMoveMemory(
void
*,
const
void
*,
size_t
count );
RtlMoveMemory( dst, src, count );
}
#else /* defined (_M_MRX000) || defined (_M_ALPHA) || defined (_M_PPC) */
/*
* copy from lower addresses to higher addresses
*/
while
(count--) {
*(
char
*)dst = *(
char
*)src;
dst = (
char
*)dst + 1;
src = (
char
*)src + 1;
}
#endif /* defined (_M_MRX000) || defined (_M_ALPHA) || defined (_M_PPC) */
return
(ret);
}
|
coreutils中:
void *memcpy (void *destaddr,void const *srcaddr, size_t len){ char *dest = destaddr; char const *src = srcaddr; while (len-- > 0) *dest++ = *src++; return destaddr;}
Linux中:
void *memcpy(void *dest, const void *src, size_t count){ assert(dest != NULL && src != NULL); char *tmp = dest; const char *s = src; while (count--) *tmp++ = *s++ ; return dest;}
程序例example1
作用:将s中的字符串复制到字符数组d中。
// memcpy.c#include <stdio.h>#include <string.h>int main(){ char *s="Golden Global View"; char d[20]; clrscr(); memcpy(d,s,(strlen(s)+1)); printf("%s",d); getchar(); return 0;}
输出结果:Golden Global View
example2
作用:将s中第14个字符开始的4个连续字符复制到d中。(从0开始)
#include <string.h>int main(){ char *s="Golden Global View"; char d[20]; memcpy(d,s+14,4); //从第14个字符(V)开始复制,连续复制4个字符(View) //memcpy(d,s+14*sizeof(char),4*sizeof(char));也可 d[4]='\0'; printf("%s",d); getchar(); return 0;}
输出结果: View
example3
作用:复制后覆盖原有部分数据
#include <stdio.h>#include <string.h>int main(void){ char src[] = "******************************"; char dest[] = "abcdefghijlkmnopqrstuvwxyz0123as6"; printf("destination before memcpy: %s\n", dest); memcpy(dest, src, strlen(src)); printf("destination after memcpy: %s\n", dest); return 0;}
输出结果:
destination before memcpy:abcdefghijlkmnopqrstuvwxyz0123as6
destination after memcpy: ******************************as6
推荐:
常见的错误:
http://blog.youkuaiyun.com/limpidfabulous/article/details/6899203
推荐:
- //copyright@July 2013/9/24
- void* memcpy(void *dst, const void *src, size_t count)
- {
- //安全检查
- assert( (dst != NULL) && (src != NULL) );
- unsigned char *pdst = (unsigned char *)dst;
- const unsigned char *psrc = (const unsigned char *)src;
- //防止内存重复
- assert(!(psrc<=pdst && pdst<psrc+count));
- assert(!(pdst<=psrc && psrc<pdst+count));
- while(count--)
- {
- *pdst = *psrc;
- pdst++;
- psrc++;
- }
- return dst;
- }
常见的错误:
http://blog.youkuaiyun.com/limpidfabulous/article/details/6899203