memcpy与memmove的自我实现

memcpy

原型:(void * memcpy ( void * destination, const void * source, size_t num );)

用法:#include <string.h>

 1.首先我们要先认识memcpy:

* 函数memcpysource的位置开始向后复制num个字节的数据到destination的内存位置。

* 这个函数在遇到 '\0' 的时候并不会停下来。

* 如果sourcedestination任何的重叠,复制的结果都是未定义的

#define _CRT_SECURE_NO_WARNINGS
//模拟实现memcpy
//memcpy只需要实现不重叠的拷贝就可以了
#include<stdio.h>
#include<assert.h>

void* my_memcpy(void* dest, void* src, size_t num)
{
	void* ret = dest;
	assert(dest);
	assert(src);

	while (num--)
	{
		*(char*)dest = *(char*)src;
		dest = (char*)dest + 1;
		src = (char*)src + 1;
	}
		
	return ret;
}
int main()
{

	return 0;
}

 仅供参考,如果发现错误欢迎留言,会更改!!!

/* memcpy example */
#include <stdio.h>
#include <string.h>
struct {
  char name[40];
  int age;
} person, person_copy;
int main ()
{
  char myname[] = "Pierre de Fermat";
  /* using memcpy to copy string: */
  memcpy ( person.name, myname, strlen(myname)+1 );
  person.age = 46;
  /* using memcpy to copy structure: */
  memcpy ( &person_copy, &person, sizeof(person) );
  printf ("person_copy: %s, %d \n", person_copy.name, person_copy.age );
  return 0;
}

memmove

原型:(void * memmove ( void  * destination, const void * source, size_t num );)

头文件:<string.h>

相关函数:memset、memcpy

* 和memcpy的差别就是memmove函数处理的源内存块和目标内存块是可以重叠的

* 如果源空间和目标空间出现重叠,就得使用memmove函数处理。

//memmove是需要实现重叠内存的拷贝的
void* my_memmove(void* dest, void* src, size_t num)
{
	void* ret = dest;
	assert(dest);
	assert(src);

	if (dest < src)
	{
		while (num--)
		{
			*(char*)dest = *(char)src;
			dest = (char*)dest + 1;
			src = (char*)src + 1;
		}
	}
	//else
	{
		while (num--)
				{
				*((char*)dest + num) = *((char*)src + num);
				}
	}
}
int main()
{
	return 0;
}
/* memmove example */
#include <stdio.h>
#include <string.h>
int main ()
{
  char str[] = "memmove can be very useful......";
  memmove (str+20,str+15,11);
  puts (str);
  return 0;
}

小插曲:strncmp  memcmp

内部实现:前者逐每个字符进行比较,并判当前字符是否为0; 后者逐内存块进行比较。

效率:后者自然要优,不论从内部实现上,还是系统优化上。

场景:后者无法替代前者。在项目中遇到一种情况,两个字符串比较,长度不定,前者遇到0会结束比较,后者不会,则越界。当仅仅是比较两个完整字符串的话,还是用strcmp要好,提前判len,遇到len不一样的字符串,串长者大。

memcmp

int memcmp ( const void * ptr1, const void * ptr2, size_t num );

 比较从ptr1和ptr2指针开始的num个字节

返回值如下:

 

/* memcmp example */
#include <stdio.h>
#include <string.h>
int main ()
{
  char buffer1[] = "DWgaOtP12df0";
  char buffer2[] = "DWGAOTP12DF0";
  int n;
  n=memcmp ( buffer1, buffer2, sizeof(buffer1) );
  if (n>0) printf ("'%s' is greater than '%s'.\n",buffer1,buffer2);
  else if (n<0) printf ("'%s' is less than '%s'.\n",buffer1,buffer2);
  else printf ("'%s' is the same as '%s'.\n",buffer1,buffer2);
  return 0;
}

 大致就是这些啦,谢谢!!!https://mp.csdn.net/mp_blog/creation/editor?spm=1001.2014.3001.5352

  • 12
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 10
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Responsibility-Q

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值