庫函數memcpy()與memmove()實現
根據MSDN文檔,當源區域與目標區域存在重疊時,memcpy()函數報錯,而memmove()函數可以處理重疊情況! 1
/**//*
2
* 函數名: memcpy
3
* 功 能: 從源source中拷貝n個字節到目標destin中
4
* 用 法: void *memcpy(void* destin, const void* source, size_t n);
5
* 說 明: 內存拷貝
6
*/
7
8
#include <stdio.h>
9
#include <conio.h> //getch頭文件
10
#include <assert.h> //assert頭文件
11
12
typedef unsigned char byte;
13
//typedef unsigned int size_t;
14
15
16
/**//*
17
memcpy函數,如果內存重疊則報錯
18
*/
19
//src要保留
20
void* memcpy(void* dst,const void* src,size_t count)
21

{
22
byte* pbTo = (byte*)dst;
23
byte* pbFrom = (byte*)src;
24
assert(dst!= NULL && src != NULL);//不能存在空指針
25
assert(pbTo >= pbFrom+count || pbFrom >= pbTo + count);//防止內存重疊(overlap)
26
while (count-- > 0)
27
{
28
*pbTo++ = *pbFrom++;
29
}
30
return dst;
31
}
32
33
/**//*
34
memmove函數,考慮了內存重疊的情況
35
*/
36
//src可以不保留
37
void* memmove(void* dst,const void* src,size_t count)
38

{
39
byte* pbTo = (byte*)dst;
40
byte* pbFrom = (byte*)src;
41
assert(dst != NULL && src != NULL);//不能存在空指針
42
if (dst <= src || pbTo >= pbFrom + count)//
43
{
44
while (count-- > 0)
45
{
46
*pbTo++ = *pbFrom++; //按遞增拷貝
47
}
48
}
49
else //
50
{
51
pbTo = pbTo + count -1;//overlap的情況,從高位地址向低位拷貝
52
pbFrom = pbFrom + count -1;
53
while (count-- > 0)
54
{
55
*pbTo-- = *pbFrom--; //按遞減拷貝
56
}
57
}
58
return dst;
59
}
60
61
62


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

38



39

40

41

42

43



44

45



46

47

48

49

50



51

52

53

54



55

56

57

58

59

60

61

62

posted on 2010-10-29 20:06 oliver 閱讀(3093) 評論(2) 編輯 收藏 引用 所屬分類: C/C++