Memcopy和memmove函数在linux下看了一下两个函数的源码。
两个函数都在头文件string.h中定义,函数原型为:
1
2
|
void
* __cdecl
memcpy
(
void
* dst,
const
void
* src,
size_t
count);
void
* __cdecl
memmove
(
void
* dst,
const
void
* src,
size_t
count);
|
实现代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
void
* __cdecl
memcpy
(
void
* dst,
const
void
* src,
size_t
count)
{
void
* ret = dst;
while
(count--)
{
// 注意, memcpy函数没有处理dst和src区域是否重叠的问题
*(
char
*)dst = *(
char
*)src;
dst = (
char
*)dst + 1;
src = (
char
*)src + 1;
}
return
(ret);
}
void
* __cdecl
memmove
(
void
* dst,
const
void
* src,
size_t
count)
{
void
* ret = dst;
if
(dst <= src || (
char
*)dst >= ((
char
*)src + count))
{
// 若dst和src区域没有重叠,则从起始处开始逐一拷贝
while
(count--)
{
*(
char
*)dst = *(
char
*)src;
dst = (
char
*)dst + 1;
src = (
char
*)src + 1;
}
}
else
{
// 若dst和src 区域交叉,则从尾部开始向起始位置拷贝,这样可以避免数据冲突
dst = (
char
*)dst + count - 1;
src = (
char
*)src + count - 1;
while
(count--)
{
*(
char
*)dst = *(
char
*)src;
dst = (
char
*)dst - 1;
src = (
char
*)src - 1;
}
}
return
(ret);
}
|
总结一下:
当src和dst区域没有重叠时,两个函数是完全一样的。木有重叠的条件是: dst <= src || (char *)dst >= ((char *)src + count 。否则,memcpy是不能正常工作的,memmove是可以正常工作的。
本文转自 驿落黄昏 51CTO博客,原文链接:http://blog.51cto.com/yiluohuanghun/1206234,如需转载请自行联系原作者