[C语言]内存操作的库函数实现及原理解释

本文介绍了内存操作的基础函数,包括memset用于设置内存区域的值,memcpy用于复制内存区域,而memmove则解决了内存重叠问题。在memcpy中,自我复制可能导致内存重叠,此时应使用memmove来确保安全。文章提供了详细的函数实现和使用场景分析。
摘要由CSDN通过智能技术生成

  在这篇文章中,会介绍到内存操作的相关的函数memset(), memcmp(), memcpy(),memmove()

1. memset()

  功能:指定起始地址,设置指定大小的空间内的地址值为指定值。
  函数原型:void* my_memset(void* dest, int c, size_t count)
函数实现:

void* my_memset(void* dest, int c, size_t count)
{
	assert(dest != NULL);

	char* tmpdest = (char*)dest;

	while (count-- > 0)
	{
		*tmpdest++ = c;
	}

	return dest;
}

2. memcpy()

  功能:从source的位置开始向后赋值指定个数的字节到dest的内存位置。赋值内存块遇到\0时,不会停止赋值。
  函数原型:void* memcpy(void* dest, const void* src, size_t num);
  问题:如果自身复制自身内存空间时,遇到重复部分,可能会发生内存重叠。
在这里插入图片描述
  我们期待的结果为:ababcdgh,但是结果为abababgh这就为内存重叠。在memcpy()函数中不考虑内存重叠的情况,如果不想发生这种情况要使用memmove()函数操作。
代码实现:

void* my_memcpy(void* dest, const void* src, size_t count)
{
	assert(dest != NULL && src != NULL);

	char* tmpdest = (char*)dest;
	const char* tmpsrc = (char*)src;

	while (count-- > 0)
	{
		*tmpdest++ = *tmpsrc++;
	}

	return dest;
}

3. memmove()

  功能:与memcpy()一致,但是可以防止内存重叠。在复制内存时,通过逆向复制消除内存重叠。
  函数原型:void* memcpy(void* dest, const void* src, size_t num);
  什么情况下会出现内存重叠:
在这里插入图片描述
  所以只需要处理上述一种情况即可。

代码实现:

void* my_memmove(void* dest, const void* src, size_t count)
{
	char* tmpdest = (char*)dest;
	char* tmpsrc = (char*)src;

	// 内存重叠现象出现在字符串的自我拷贝上
	// 要解决内存重叠问题,需要考虑源串与目标串的位置关系
	// 当目标串在源串指针之前或者时目标串在源串指针之后拷贝时不会发生交集现象,发生自我拷贝是不会出现内存重叠现象
	// 当目标串指针在源串指针之后并且拷贝出现交集时,这时候会发生内存重叠现象,通过反向拷贝可以解决此问题

	// 不会发生内存重叠时
	if (tmpsrc >= tmpdest || tmpdest >= tmpsrc + count)
	{
		while (count-- > 0)
		{
			*tmpdest++ = *tmpsrc++;
		}
	}
	else
	{
		// 从尾部开始赋值
		tmpdest += count - 1;
		tmpsrc += count - 1;
		while (count-- > 0)
		{
			*tmpdest-- = *tmpsrc--;
		}
	}
	
	return dest;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值