内存操作函数

43 篇文章 3 订阅

为什么引入内存操作函数在定义中字符串以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;
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值