memcpy
c和c++使用的内存拷贝函数,memcpy函数的功能是从源src所指的内存地址的起始位置开始拷贝n个字节到目标dst所指的内存地址的起始位置中。
函数原型
void *memcpy(void *dst, const void *src, size_t n);
功能
从源src所指的内存地址的起始位置开始拷贝n个字节到目标dst所指的内存地址的起始位置中
所需头文件
C语言:#include<string.h>
C++:#include<cstring>
返回值
函数返回指向dst的指针
程序代码:
#include<stdio.h>
#include<assert.h>
void* my_memcpy(void *dst, const void *src, size_t count)
{
assert(dst);
assert(src);
char *p1 = (char *)dst;
char *p2 = (char *)src;
char *ret = dst;
while (count--)
{
*p1 = *p2;
p1 = p1+1;
p2 = p2+1;
}
return ret;
}
int main()
{
char str[] = "abcdefghigk" ;
char arr[] = "uvwxyz" ;
char *ret = my_memcpy(str, arr,3);
printf( "%s\n", ret);
system( "pause");
return 0;
}
1、const修饰
源字符串参数用const修饰,防止修改源字符串。
2、空指针检查
(A)不检查指针的有效性,说明你不注重代码的健壮性。
(B)检查指针的有效性时使用assert(dst && src)。
说明
source和det所指的内存区域可能重叠,但是如果source和dst所指的内存区域重叠,那么这个函数并不能够确保source所在重叠区域在拷贝之前不被覆盖。而使用memmove可以用来处理重叠区域。函数返回指向dst的指针。
memmove
memmove用于从src拷贝count个字符到dest,如果目标区域和源区域有重叠的话,memmove能够保证源串在被覆盖之前将重叠区域的字节拷贝到目标区域中。但复制后src内容会被更改。但是当目标区域与源区域没有重叠则memcpy函数功能相同。
原型
void *memmove( void* dest, const void* src, size_t count );
头文件
<string.h>
功能
由src所指内存区域复制count个字节到dest所指内存区域
程序代码:
#include<stdio.h>
#include<assert.h>
void *my_memmove(void *dst, const void *src, size_t count)
{
assert(dst);
assert(src);
char *p1 = (char *)dst;
char *p2 = (char *)src;
char *ret = dst;
if (p1 > p2 || p1 < (p2 + count))
{
while (count--)
{
*p1 = *p2;
p1 = p1+1;
p2 = p2+1;
}
}
else
{
p1 = p1 + count - 1;
p2 = p2 + count - 1;
while (count--)
{
*p1 = *p2;
p1 = p1 - 1;
p2 = p2 - 1;
}
}
return ret;
}
int main()
{
char str[] = "abcdefgh" ;
char arr[] = "uvmxyz" ;
char *ret = my_memmove(str, arr,6);
printf( "%s\n", ret);
system( "pause");
return 0;
}
1、const修饰
源字符串参数用const修饰,防止修改源字符串。
2、空指针检查
(A)不检查指针的有效性,说明你不注重代码的健壮性。
(B)检查指针的有效性时使用assert(dst && src)。
希望能帮助大家,谢谢!