C语言内存函数及模拟实现

发布于:2024-04-29 ⋅ 阅读:(41) ⋅ 点赞:(0)

之前写的字符函数都只针对字符串,而内存函数是针对内存的,不在乎内存里面是什么。

memcpy

函数介绍

void * memcpy ( void * destination, const void * source, size_t num );
函数memcpy从source的位置开始向后复制num个字节的数据到destination指向的内存位置。
这个函数在遇到’\0’ 的时候并不会停下来。
如果source和destination有任何的重叠,复制的结果都是未定义的。

int main()
{
	int arr1[] = { 1,2,3,4,5,6,7,8,9,10 };
	int arr2[10] = { 0 };
	memcpy(arr2, arr1, 20);
	int i = 0;
	for (i = 0; i < 10; i++)
	{
		printf("%d ", arr2[i]);
	}
	return 0;
}

模拟实现

void* my_memcpy(void* str1, const void* str2, size_t num)
{
	void* ret = str1;
	assert(str1 && str2);
	while (num--)
	{
		*(char*)str1 = *(char*)str2;
		str1 = (char*)str1 + 1;
		str2 = (char*)str2 + 1;
	}
	return ret;
}

由于memcpy函数的特性,不能拷贝内存重叠的区域,拷贝内存重叠区域可以使用memmove函数。

memmove

函数介绍

void *memmove(void *str1, const void *str2, size_t n)
从 str2 复制 n 个字符到 str1,但是在重叠内存块这方面,memmove() 是比 memcpy() 更安全的方法。如果目标区域和源区域有重叠的话,memmove() 能够保证源串在被覆盖之前将重叠区域的字节拷贝到目标区域中,复制后源区域的内容会被更改。如果目标区域与源区域没有重叠,则和 memcpy() 函数功能相同。

模拟实现

void* my_memmove(void* str1, const void* str2, size_t num)
{
	void* ret = str1;
	assert(str1 && str2);
	if (str1 < str2)
	{
		while (num--)
		{
			*(char*)str1 = *(char*)str2;
			str1 = (char*)str1 + 1;
			str2 = (char*)str2 + 1;
		}
	}
	else
	{
		while (num--)//进入循环刚好少1,比如拷贝5个,刚好是 +4
		{
			*((char*)str1 + num) = *((char*)str2 + num);
		}
	}
	return ret;
}

memset

内存设置函数。

函数介绍

void *memset(void *str, int c, size_t n)用于将一段内存区域设置为指定的值。
memset() 函数将指定的值 c 复制到 str 所指向的内存区域的前 n 个字节中,这可以用于将内存块清零或设置为特定值。注意是以字节为单位,而不是整型。

在一些情况下,需要快速初始化大块内存为零或者特定值,memset() 可以提供高效的实现。

memcmp

内存比较函数

int memcmp(const void *str1, const void *str2, size_t n)
str1 – 指向内存块的指针。
str2 – 指向内存块的指针。
n – 要被比较的字节数。
从参数地址开始比较,按照字节单位向后比较
如果返回值 < 0,则表示 str1 小于 str2。
如果返回值 > 0,则表示 str1 大于 str2。
如果返回值 = 0,则表示 str1 等于 str2。