为什么引入内存操作函数在定义中字符串以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;
}