memcpy

1函数原型编辑

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

2功能编辑

从源src所指的内存地址的起始位置开始拷贝n个字节到目标dest所指的内存地址的起始位置中

3所需头文件编辑

C语言中使用#include <string.h>;
C++中使用#include <cstring>和#include <string.h>都可以。前者只是为了凸显C++风格。

4返回值编辑

函数返回指向dest的指针。

5说明编辑

1.source和destin所指的内存区域可以重叠,但是如果source和destin所指的内存区域重叠,那么这个函数并不能够确保source所在重叠区域在拷贝之前被覆盖。而使用memmove可以用来处理重叠区域。函数返回指向destin的 指针.
2.如果目标数组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, 
constvoid* src, 
size_tcount 
void* ret = dst; 
#if defined (_M_MRX000) || defined (_M_ALPHA) || defined (_M_PPC) 
externvoidRtlMoveMemory( void*, constvoid*, size_tcount ); 
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中:

?
1
2
3
4
5
6
7
8
9
10
void*memcpy(void*destaddr,voidconst*srcaddr, size_tlen) 
char*dest = destaddr; 
charconst*src = srcaddr; 
while(len-- > 0) 
*dest++ = *src++; 
returndestaddr; 
}
Linux中:
?
1
2
3
4
5
6
7
8
9
10
void*memcpy(void*dest, constvoid*src, size_tcount) 
assert(dest != NULL && src != NULL); 
char*tmp = dest;    constchar*s = src; 
while(count--) 
*tmp++ = *s++ ; 
returndest; 
}
程序例example1
作用:将s中的字符串复制到字符数组d中。
?
1
2
3
4
5
6
7
8
9
10
11
12
// memcpy.c 
#include <stdio.h> 
#include <string.h> 
intmain() 
char*s="Golden Global View"
chard[20]; 
clrscr(); 
memcpy(d,s,( strlen(s)+1) ); 
printf("%s",d); 
getchar(); 
return0;
}
输出结果:Golden Global View
example2
作用:将s中第14个字符开始的4个连续字符复制到d中。(从0开始) 
?
1
2
3
4
5
6
7
8
9
10
11
#include <string.h> 
intmain( 
char*s="Golden Global View"
chard[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(); 
return0; 
}
输出结果: View
example3
作用:复制后覆盖原有部分数据
?
1
2
3
4
5
6
7
8
9
10
11
#include <stdio.h> 
#include <string.h> 
intmain(void
charsrc[] = "******************************"
chardest[] = "abcdefghijlkmnopqrstuvwxyz0123as6"
printf("destination before memcpy: %s\n", dest); 
memcpy(dest, src, strlen(src)); 
printf("destination after memcpy: %s\n", dest); 
return0; 
}
输出结果:
destination before memcpy:abcdefghijlkmnopqrstuvwxyz0123as6
destination after memcpy: ******************************as6

7与strcpy函数的区别编辑

strcpy和memcpy主要有以下3方面的区别。
1、复制的内容不同。 strcpy只能复制 字符串,而memcpy可以复制任意内容,例如 字符数组、整型、 结构体等。
2、复制的方法不同。strcpy不需要指定长度,它遇到被复制字符的串结束符"\0"才结束,所以容易溢出。memcpy则是根据其第3个参数决定复制的长度。
3、用途不同。通常在复制字符串时用strcpy,而需要复制其他类型数据时则一般用memcpy
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值