解决:Cortex-M4上,usart自己主动发送数据计划。

    1. usart快速突破。数据还没有被处理。usart中断会把盖掉的数据不被处理。

数据丢失。

	2.此过程需要main处理4一个usart口的数据,这样出错的概率会更大。

提出例如以下解决方式:
第一:规定每条完毕的数据长度。步会超过256字节。
第二:我们规定数据的结束表标志为数据的后三位为,FFFFFF
第三:定义一个全局的数据,他是一个三维数组该数据用来存放4个usart口发上来的数据。 uint8_t usart_data[4][5][256];
以下解析为什么要定义一个三维数组: 第一个下标4:它分别用来接受不同的usart口的数据。
第二个下标5:它表示每一个usart最多能缓存的数据条数是5.
第三个下标256:它用来表示最多一条数据能存256个字节。 以下是程序假设实现。 定义例如以下变量:
一:接受usart数据缓冲器的定义。它是一个全局的三维数据
uint8_t usart_data[4][5][256] = {0}; 二:记录每一个usart口。当前接收到的数据条数。
uint8_t data_count[4] = {0}; 三:记录当前接受到的数据数。
uint8_t data_len[4] = {0}; 四:用来记录出错的次数。
uint8_t error_count = 0; void UART_DATA_handle(uint8_t route)
{ if(data_count[route]<5)
{ if((usart_data[route][data_count[route]][data_len[route]-3]==0xFF)
&&(usart_data[route][data_count[route]][data_len[route]-2]==0xFF)
&&(usart_data[route][data_count[route]][data_len[route]-1]==0xFF))
{ if(usart_data[route][data_count[route]][0]==data_len[route])
{
data_count[route]++;
data_len[route] = 0;
if(data_count[route]>5)
{ data_count[route]=0;
}
else
{
error_count++;
}
}
}
}
} void USART1_IRQHANDLER(void)
{
if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET)
{
USART_ClearITPendingBit(USART1, USART_IT_RXNE); usart_data[0][data_cout[0]][data_len[0]++] = USART_Rece_Data(USART1);
if(data_len[0]>2)
{ usart_data_route(0);
}
}
return;
} void USART2_IRQHANDLER(void)
{
if(USART_GetITStatus(USART2, USART_IT_RXNE) != RESET)
{
USART_ClearITPendingBit(USART2, USART_IT_RXNE);
usart_data[1][data_cout[1]][data_len[1]++] = USART_Rece_Data(USART2);
if(data_len[1]>2)
{
usart_data_route(1);
}
}
return;
} void USART3_IRQHANDLER(void)
{
if(USART_GetITStatus(USART3, USART_IT_RXNE) != RESET)
{
USART_ClearITPendingBit(USART3, USART_IT_RXNE);
usart_data[2][data_cout[2]][data_len[2]++] = USART_Rece_Data(USART3);
if(data_len[2]>2)
{
usart_data_route(2);
}
}
return;
} void USART4_IRQHANDLER(void)
{
if(USART_GetITStatus(USART4, USART_IT_RXNE) != RESET)
{
USART_ClearITPendingBit(USART4, USART_IT_RXNE);
usart_data[3][data_cout[3]][data_len[3]++] = USART_Rece_Data(USART4);
if(data_len[3]>2)
{
usart_data_route(3);
}
}
return;
} /****main*******/ uint8_t tmp[512] = {0}; static __INLINE void process_usartdata(uint8_t *tmpdata, uint8_t *usartdata, char *usart_format, int flag){
int tmp =0,count=0,i=0;
memset(tmpdata,0x00,512);
printf(usart_format,flag);
for(i=0;i<usartdata[0]+1;i++){
tmp = sprintf(&tmpdata[count],"%02X", *(usartdata+i));
count += tmp;
}
memset(usartdata,0x00,256);
printf(tmpdata);
} int main(void)
{
.........
uint8_t i = 0;
while(1)
{
for(i=0;i<4;i++)
{ while(data_count[i]>0)
{
process_usartdata(tmp,usart_data[i][data_count[i]],"usart:%d",i);
data_count[i]--;
}
if(data_count[i]>5)
{
data_count[i] = 0;
}
}
}
........
}

版权声明:本文博客原创文章,博客,未经同意,不得转载。

F4107Usart数据处理程序的更多相关文章

  1. 23个适合Java开发者的大数据工具和框架

    转自:https://www.yidianzixun.com/article/0Ff4gqZQ?s=9&appid=yidian&ver=3.8.4&utk=6n9c2z37 ...

  2. 大数据-kafka

    1Kafka是一种高吞吐量的分布式发布订阅消息系统,它可以处理消费者规模的网站中的所有动作流数据. 作用:1发布和订阅消息流,这个功能类似于消息队列,这也是kafka归类为消息队列框架的原因 2以容错 ...

  3. Spark项目之电商用户行为分析大数据平台之(六)用户访问session分析模块介绍

    一.对用户访问session进行分析 1.可以根据使用者指定的某些条件,筛选出指定的一些用户(有特定年龄.职业.城市): 2.对这些用户在指定日期范围内发起的session,进行聚合统计,比如,统计出 ...

  4. Python 学习 第17篇:从SQL Server数据库读写数据

    在Python语言中,从SQL Server数据库读写数据,通常情况下,都是使用sqlalchemy 包和 pymssql 包的组合,这是因为大多数数据处理程序都需要用到DataFrame对象,它内置 ...

  5. Java程序员必备的10个大数据框架!

    作者:java妞妞 blog.csdn.net/javaniuniu/article/details/71250316 当今IT开发人员面对的最大挑战就是复杂性,硬件越来越复杂,OS越来越复杂,编程语 ...

  6. 徒手打造基于Spark的数据工厂(Data Factory):从设计到实现

    在大数据处理和人工智能时代,数据工厂(Data Factory)无疑是一个非常重要的大数据处理平台.市面上也有成熟的相关产品,比如Azure Data Factory,不仅功能强大,而且依托微软的云计 ...

  7. [摘录]第三部分 IBM文化(1)

    第二十章 论公司文化如果是在20世纪90年代初期,当一个人看见或者听到“IBM”时,他会联想到什么呢?或许是“大计算机”.“个人电脑”或者“ThinkPads”.但是,他们同时也必然会想到“大公司”. ...

  8. TSQL Merge On子句和When not matched 语义理解

    Merge 的On子句指定Match condition,When子句指定过滤条件,如果Source Table和Targe Table匹配的上,很好理解:如果匹配不上,必须深入理解不匹配的条件,否则 ...

  9. 来自沪江、滴滴、蘑菇街架构师的 Docker 实践分享

    架构师小组交流会是由国内知名公司架构师参与的技术交流会,每期选择一个时下最热门的技术话题进行实践经验分享. Docker 作为当前最具颠覆性的开源技术之一,其轻量虚拟化.可移植性是 CI/CD.Dev ...

随机推荐

  1. 同步(Synchronization)

    多线程应用程序的存在,在运行打开一个潜在的多线程安全的接入资源. 两个线程相同的资源可能会以意想不到的方式改变相互干扰. 例如.一个线程可以覆盖有一个线程改变或使应用程序进入一个潜在的无效的状态未知. ...

  2. 一个vbs文件将指定文件夹下的文件名输出到指定文件夹下

    'on error resume NextConst MY_COMPUTER=&H11& Const WINDOW_HANDLE=0 Const OPTIONS=0 '设置我的电脑为根 ...

  3. SQL Server -减少代码触发的负担

    触发器是一张表的增删改操作,引起或触发对还有一张表的增删改操作,所以触发器便有3种类型.各自是deleted触发器.Update触发器,insert触发器 触发器又依据替换原来的增删改操作,还是在原来 ...

  4. ASP.NET MVC常见问题解决方法

    1.页面报错: The following errors occurred while attempting to load the app. - No assembly found containi ...

  5. 揭秘上海传智播客平均工资超过7k 其中一位知情人士

    大学毕业生人数破700万大关.如何破解"毕业即失业"中国式的大学困境? 2014年全国高校毕业生总数将达到727万人,比被称为"史上最难就业年"的2013年再添 ...

  6. Entity Framework笔记(二)

    前几日学习了在VS2010Console项目中使用Entity Framework,并且使用Code First模式.通过编写Model类,来生成数据库对应的表.并且,往表中写入数据以及获取表中的所有 ...

  7. css Tab选项卡2

    注意上述 红色方框   这个是锚点的变相  以及overflow:hiden结合, 利用  锚点对应 id  ,  也可以实现. 兼容ie6+  适合手机tab 简单   不需要脚本 其实还可以利用 ...

  8. Android通过意图使用内置的音频播放器

    假设实现一个音频文件的播放,那么在应用程序中提供播放音频文件功能的最简单的方式是利用内置的"Music(音乐)"应用程序的功能--即使用系统自带的或已安装好的音乐播放器来播放指定的 ...

  9. C#版的抓包软件

    C#版的抓包软件   [创建时间:2015-09-10 22:37:04] NetAnalyzer下载地址 不好意思啊,NetAnalyzer停更有点长了,今天继续填坑^&^ NetAnaly ...

  10. SVD在推荐系统中的应用

    一.奇异值分解SVD 1.SVD原理 SVD将矩阵分为三个矩阵的乘积,公式: 中间矩阵∑为对角阵,对角元素值为Data矩阵特征值λi,且已经从大到小排序,即使去掉特征值小的那些特征,依然可以很好地重构 ...