void CopeSerial_1_Data(unsigned char ucData){ static unsigned char ucRxBuffer[250]; static unsigned char ucRxCnt = 0; //LED_REVERSE(); //接收到数据,LED灯闪烁一下
ucRxBuffer[ucRxCnt++]=ucData; //将收到的数据存入缓冲区中 if (ucRxBuffer[0]!=0xBB) //数据头不对,则重新开始寻找0xBB数据头 { ucRxCnt=0; return; } if (ucRxCnt>30) {return;} //数据溢出,则返回 if (ucData!=0x0A) {return;}//数据接收到了0x0A 接收中断(接收到的数据必须是0x0d 0x0a结尾) else { switch(ucRxBuffer[1])//判断数据是哪种数据,然后将其拷贝到对应的结构体中,有些数据包需要通过上位机打开对应的输出后,才能接收到这个数据包的数据 { case 0xA1: memcpy(&L1_RX_DATA,&ucRxBuffer[21],1);break;//memcpy为编译器自带的内存拷贝函数,需引用"string.h",将接收缓冲区的字符拷贝到数据结构体里面,从而实现数据的解析。 case 0xA2: receive_rfid_Station[0]=ucRxBuffer[21];break; //memcpy为编译器自带的内存拷贝函数,需引用"string.h",将接收缓冲区的字符拷贝到数据结构体里面,从而实现数据的解析。 default: break; } ucRxCnt=0;//清空缓存区 } }C 库函数 -
memcpy() C 标准库 -
描述
C 库函数 void *memcpy(void *str1, const void *str2, size_t n) 从存储区 str2 复制 n 个字节到存储区 str1。
声明
下面是 memcpy() 函数的声明。
void *memcpy(void *str1, const void *str2, size_t n)参数
- str1 -- 指向用于存储复制内容的目标数组,类型强制转换为 void* 指针。
- str2 -- 指向要复制的数据源,类型强制转换为 void* 指针。
- n -- 要被复制的字节数。
返回值
该函数返回一个指向目标存储区 str1 的指针。
实例
下面的实例演示了 memcpy() 函数的用法。
实例
#include <stdio.h>
#include <string.h>
int main ()
{
const char src[50] = "http://www.runoob.com";
char dest[50];
memcpy(dest, src, strlen(src)+1);
printf("dest = %s\n", dest);
return(0);
}
让我们编译并运行上面的程序,这将产生以下结果:
dest = http://www.runoob.com将 s 中第 11 个字符开始的 6个连续字符复制到 d 中:
实例
#include <stdio.h>
#include<string.h>
int main()
{
char *s="http://www.runoob.com";
char d[20];
memcpy(d, s+11, 6);
d[6]='\0';
printf("%s", d);
return 0;
}
让我们编译并运行上面的程序,这将产生以下结果:
runoob覆盖原有部分数据:
实例
#include<stdio.h>
#include<string.h>
int main(void)
{
char src[] = "***";
char dest[] = "abcdefg";
printf("使用 memcpy 前: %s\n", dest);
memcpy(dest, src, strlen(src));
printf("使用 memcpy 后: %s\n", dest);
return 0;
}
让我们编译并运行上面的程序,这将产生以下结果:
使用 memcpy 前: abcdefg
使用 memcpy 后: ***defg C 标准库 -
作者: minicaihong, 来源:面包板社区
链接: https://mbb.eet-china.com/blog/uid-me-1521958.html
版权声明:本文为博主原创,未经本人允许,禁止转载!
文章评论(0条评论)
登录后参与讨论