用C语言模拟实现memcpy函数,memmove函数

一. memcpy函数

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

复制内存块
将num字节的值从源指向的位置直接复制到目标指向的内存块。

源指针和目标指针所指向的对象的底层类型与此函数无关;结果是数据的二进制副本。

该函数不检查源文件中的任何终止空字符——它总是准确地复制num字节。

为了避免溢出,目标和源参数所指向的数组的大小应该至少为num字节,并且不应该重叠(对于重叠的内存块,memmove是一种更安全的方法)。

参数
1. destination
指向要复制内容的目标数组的指针,类型转换为void*类型的指针。
2. source
指向要复制的数据源的指针,类型转换为const void*类型的指针。
3. num
要复制的字节数。Size_t是无符号整型。

代码实现:

#include <stdio.h>
#include <string.h>

struct 
{
  char name[40];
  int age;
} person, person_copy;

int main ()
{
  char myname[] = "Prica Kordires";

  /* 使用memcpy复制字符串 */
  memcpy ( person.name, myname, strlen(myname)+1 );
  person.age = 40;

  /* 使用memcpy复制结构体 */
  memcpy ( &person_copy, &person, sizeof(person) );

  printf ("person_copy: %s, %d \n", person_copy.name, person_copy.age );

  return 0;
}

二. memmove函数

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

移动内存块
将num字节的值从源指向的位置复制到目标指向的内存块。复制发生时,就像使用了中间缓冲区一样,允许目标和源重叠。

源指针和目标指针所指向的对象的底层类型与此函数无关;结果是数据的二进制副本。

该函数不检查源文件中的任何终止空字符——它总是准确地复制num字节。

为了避免溢出,目标参数和源参数所指向的数组的大小应该至少为num字节。

参数
1. destination
指向要复制内容的目标数组的指针,类型转换为void*类型的指针。
2. source
指向要复制的数据源的指针,类型转换为const void*类型的指针。
3. num
要复制的字节数。Size_t是无符号整型。

代码实现:

#include<stdio.h>
#include<assert.h>

void my_memmove(void* dest, const void* src, size_t num)
{
	char* str1 = (char*)dest;
	const char* str2 = (const char*)src;
	assert(dest && src);

	if (str1 > str2 && str1 < str2 + num)
	{
		while (num--)
		{
			*(str1 + num) = *(str2 + num);
		}
	}
	else
	{
		while (num--)
		{
			*str1 = *str2;
			str1++;
			str2++;
		}
	}
}
int main()
{
	char str[] = "memmove can be very useful......";
	my_memmove(str + 20, str + 15, 11);
	puts(str);
	return 0;
}

猜你喜欢

转载自blog.csdn.net/m0_72000264/article/details/128642779