memcpy

memcpy

memcpy的函數原型是void *memcpy(void *dest, const void *src, size_t n),其功能是從源src所指的內存地址的起始位置開始拷貝n個位元組到目標dest所指的內存地址的起始位置中。memcpy則是根據其第3個參數決定複製的長度。函數返回指向destin的指針,作用為:將s中第13個字元開始的4個連續字元複製到d中。strcpy只能複製字元串,而memcpy可以複製任意內容,例如字元數組、整型、結構體、類等。strcpy不需要指定長度,它遇到被複制字元的串結束符"\0"才結束,所以容易溢出。

函數原型


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

功能


從源src所指的內存地址的起始位置開始拷貝n個位元組到目標dest所指的內存地址的起始位置中

所需頭文件


C語言:#include
C++:#include

說明


1.source和destin所指的內存區域可能重疊,但是如果source和destin所指的內存區域重疊,那麼這個函數並不能夠確保source所在重疊區域在拷貝之前不被複蓋。而使用memmove可以用來處理重疊區域。函數返回指向destin的指針.
2.如果目標數組destin本身已有數據,執行memcpy()后,將復蓋原有數據(最多復蓋n)。如果要追加數據,則每次執行memcpy后,要將目標數組地址增加到你要追加數據的地址。
注意:source和destin都不一定是數組,任意的可讀寫的空間均可。

函數實現


Linux中

程序例example1
輸出結果:Golden Global View
example2
作用:將s中第13個字元開始的4個連續字元複製到d中。(從0開始)
輸出結果:View
example3
作用:複製后復蓋原有部分數據
輸出結果:
destination before memcpy:abcdefghijlkmnopqrstuvwxyz0123as6
destination after memcpy: ******************************as6

區別


strcpy和memcpy主要有以下3方面的區別。
1、複製的內容不同。strcpy只能複製字元串,而memcpy可以複製任意內容,例如字元數組、整型、結構體、類等。
2、複製的方法不同。strcpy不需要指定長度,它遇到被複制字元的串結束符"\0"才結束,所以容易溢出。memcpy則是根據其第3個參數決定複製的長度。
3、用途不同。通常在複製字元串時用strcpy,而需要複製其他類型數據時則一般用memcpy

案例


example1
1
2
3
4
5
6
7
8
9
10
11
12
13
// memcpy.c
#include
#include
int main ()
{
char *s="Golden Global View";
char d[20];
clrscr();
memcpy(d,s,(strlen(s)+1));
printf("%s",d);
getchar();
return 0;
}
example2
1
2
3
4
5
6
7
8
9
10
11
12
#include
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;
}
example3
1
2
3
4
5
6
7
8
9
10
11
#include
#include
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;
}