为什么引入内存操作函数:在定义中字符串以NUL(空字节)结尾,所以字符串操作函数遇见‘\0’停止。因此我们引入内存操作函数,来解决“非字符串类型”中遇到NUL(数字0)的情况。
内存操作函数:内存操作函数与字符串操作函数非常类似,只不过内存操作函数能够处理任何类型的字节序列。在内存操作函数的参数中,有一个显示的参数说明了要处理的字节数,所以他遇见NUL不会停下来。
下面介绍两种常用的内存操作函数原型:
void *memcpy(void *dst,void const *src,sizt_t len);
memcpy从src的起始位置复制len个“字节”到dst中,可以复制任何类型的值,但是如果dst和src发生重叠,其结果是未定义的。
memcpy功能的实现:
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
void * my_memcpy(void *dst, void const * src, int len)
{
char *p1=dst ;
char *p2 = src ;
while (len --)
{
*p1++= *p2++;
}
return dst ;
}
int main()
{
int arr1[100] = { 0 };
int arr2[100]={23,1,2,3,4,5,6,7,8,9,10,11,12};
int len = 0;
scanf( "%d", &len);
int *ret =my_memcpy(arr1, arr2, len*sizeof (arr2[0]));
printf( "%#p\n",&*ret);
system( "pause");
return 0;
}
void *memmove(void *dst,void const *src,size_t len);
memmove的行为与memcpy差不多,不过memmove考虑了src与dst重叠的情况。
memmove功能的实现:
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
void * my_memmove(void *dst, void const * src, int len)
{
assert( dst != NULL);
assert( src != NULL);
char *p1 = dst ;
char *p2 = src ;
if ((p1 >= p2) && (p2 > p1 + len))
{
for (int i = len - 1; i >= 0; i--)
p1[i] = p2[i];
}
else
for (int i = 0; i < len; i++)
{
p1[i] = p2[i];
}
return dst ;
}
int main()
{
int arr1[100] = { 0 };
int arr2[100] = { 10, 1, 2, 3, 4, 5, 6, 7, 8, 9, 11, 12, 23 };
int len = 0;
scanf( "%d", &len);
int *ret = my_memmove(arr1, arr2, sizeof (arr2[0])*len);
printf( "%#p\n",&*ret);
system( "pause");
return 0;
}