C语言内存函数

1. memcpy的模拟实现

void * memcpy ( void * dst, const void * src, size_t count)
{
 void * ret = dst;
 assert(dst);
 assert(src);
 /*
 * copy from lower addresses to higher addresses
 */
 while (count--) 
 {
 *(char *)dst = *(char *)src;
 dst = (char *)dst + 1;
 src = (char *)src + 1;
 }
 return(ret);
}

上面这段代码的意思是:设置两个参数为空指针和字节数的函数,函数内部由assert函数确保两个指针参数不是空指针,接下来是一个while循环,实现了src有效地址的所有字节赋给dst,以实现数组内容的拷贝

2.memmove 的模拟实现

void* My_memmove(void* des, const void* src, size_t count)
{
	assert(des && src);
	void* ret = des;
	if (des < src)
	{
		while (count--)
		{
			*(char*)des = *(char*)src;
			des = (char*)des + 1;
			src = (char*)src + 1;
		}
	}
	else
	{
		while (count--)
		{
			*((char*)des + count)= *((char*)src + count);
		}
		
	}

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

memmove可以用来处理一个数组内的拷贝,和memcpy的差别就是memmove函数处理的源内存块和⽬标内存块是可以重叠的。 • 如果源空间和⽬标空间出现重叠,就得使⽤memmove函数处理。

3.⼤⼩端字节序和字节序判断

1. 什么是⼤⼩端?

其实超过⼀个字节的数据在内存中存储的时候,就有存储顺序的问题,按照不同的存储顺序,我们分 为⼤端字节序存储和⼩端字节序存储,下⾯是具体的概念: ⼤端(存储)模式:是指数据的低位字节内容保存在内存的⾼地址处,⽽数据的⾼位字节内容,保存 在内存的低地址处。 ⼩端(存储)模式:是指数据的低位字节内容保存在内存的低地址处,⽽数据的⾼位字节内容,保存 在内存的⾼地址处。 上述概念需要记住,⽅便分辨⼤⼩端。

大小端之分只是元素内部在内存上的存储布局,当需要取出数据时,取出的数据不会变且顺序相同,如取地址无论大小端都是取出的最小字节端的地址。

  • 9
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值