内存函数实现------memcpy

我们先看memcpy函数的效果图

我们的核心思想是,将要复制的大小(单位字节传输过去),然后在实现函数中一个字节一个字节的复制

memcpy可以实现所有类型数据的复制,所以我们的定义部分如下

void* my_memcpy(void* dest,const void* str,unsigned int num)

dest是进行复制的目标地址(无类型),str是源头地址(无类型),num为需要复制的字节数(无符号整形)

以下为具体实现过程

	assert(dest&&str);
	void* tmp = dest;
	while (num--)
	{
		*(char*)dest = *(char*)str;
		++(char*)dest;
		++(char*)str;
	}
	return tmp;

开头断言(防止空指针的传入)

拷贝一份目标数组的起始地址放到临时变量中

循环开始,我们需要拷贝num次,每次自减,知道减完为0跳出循环

循环内部

将传入的无类型指针强制转换为char*(每次访问一个字节)然后解应用找到,传完一个字节后自增。循环结束后返回目标地址的首地址

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
DSP memcpy函数是用于在DSP系统中进行内存复制函数。它可以将一段内存中的数据复制到另一段内存中,以实现数据的传输和处理。在C语言中,memcpy函数的原型为: void *memcpy(void *destination, const void *source, size_t num); 其中,destination是目标内存的起始地址,source是源内存的起始地址,num是要复制的字节数。该函数的返回值是目标内存的起始地址。 在引用中的代码中,并没有直接使用memcpy函数,而是通过将数据写入寄存器的方式进行数据的拷贝和传输。这段代码初始化了SPI控制器,设置了波特率、标志位和控制寄存器的值。具体的操作包括设置波特率为10、设置标志位FLS2、设置控制寄存器的值为0x1001|CPHA|CPOL、设置控制寄存器的值为原值或上SPE。这些操作旨在配置SPI控制器的工作模式和相关参数。 在引用中的代码中,并没有直接使用memcpy函数,而是通过访问寄存器的方式进行数据的读写操作。这段代码实现了SPI的字节读写操作,其中包括等待SPI标志位SPIF的状态变为1、将数据写入发送寄存器、等待接收寄存器非空并将接收到的数据保存在incoming变量中。最后,返回接收到的数据。 在引用中的代码中,同样没有直接使用memcpy函数,而是通过将数据写入寄存器的方式进行数据的设置和配置。这段代码初始化了MMC硬件,包括设置标志位FLS2、设置波特率为4、设置控制寄存器的值为0x0000、设置控制寄存器的值为原值或上MSTR、设置控制寄存器的值为原值或上SPE。这些操作旨在配置MMC硬件的工作模式和相关参数。 综上所述,引用、引用和引用中的代码并没有直接使用到memcpy函数,而是通过寄存器的读写方式实现了数据的复制和传输。这些代码用于配置SPI控制器和MMC硬件的工作模式和相关参数。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值