专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
51单片机以中断的方式发送,只能成功一次,第二次就不成功,求赐教,附源码。
2019-03-24 18:49
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
51单片机
13980
3
1094
求大虾赐教! 此帖出自
小平头技术问答
友情提示:
此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
3条回答
ddllxxrr
1楼-- · 2019-03-24 21:11
static void write_data(void)
{
static uchar send_length = sizeof(SendBuf); //这里把要发送的数据的长度定义为静态变量,用它来判断是否发送完
static uchar send_head=0;
if(send_length == 0) //如果无数据发送,就退出
{
//关闭串口中断
TI=0;
send_head=0;
return;
}
else
{
send_length--;
SBUF = SendBuf[send_head++];
}
}
/****************************************
串口接收中断
****************************************/
void UART_Receive(void) interrupt 4
{
if(RI)
{
RI=0;
// ReceiveBuf[length++]=SBUF; //接收串口数据
}
if(TI) //如果是发送中断
{
TI=0; //清除中断标志位
write_data(); //调用发送函数
TI = 1;
}
}
加载中...
zpf19910506
2楼-- · 2019-03-24 22:05
我已经找到原因了,虽然你说的不对,但还是很谢谢你!原因是我在write_data函数中把send_length定义成了静态变量。它的值只能被初始化一次,当第一次发送完成后,它的值就永远为0了。
#define _UART_C
#include "includes.h"
static void write_data(void);
static INT8U send_length = 0; //这里把要发送的数据的长度定义为静态变量,
//用它来判断是否发送完,它的值在send_data函数中被赋值
//每次发送完一个字节,后在write_data中减一
/****************************************
串口初始化 9600bps 8bit 1stop
****************************************/
void Init_UART(void)
{
TMOD=0x20;
TH1=0xfd;
TL1=0xfd;
PCON=0x00;
SCON=0x50;
TR1=1;
ET1=0;
ES=1;
}
//串口发送十六进制数据
//num:要发送的数据的个数 *str:数据数组的首地址
//应用层调用此函数把要发送的数据写入发送缓冲器中。
void UART_SendData(unsigned char num,unsigned char *str)
{
INT8U i;
for(i=0;i<num;i++)
{
SendBuf
=str
;
}
send_length = i;
write_data(); //调用发送数据的函数
}
//串口发送字符串
void UART_SendString(unsigned char *str)
{
INT8U i=0;
while(str
!=' ')
{
i++;
}
UART_SendData(i+1,str);
}
static void write_data(void)
{
static INT8U send_head=0;
if(send_length == 0) //如果无数据发送,就退出
{
//关闭串口中断
TI=0;
send_head=0;
// flag_uart = 0;
//发送信号量
OSSemPost(Sem_UART);
return;
}
else
{
send_length--;
// flag_uart = 1;
SBUF = SendBuf[send_head++];
}
}
/****************************************
串口接收中断
****************************************/
void UART_Receive(void) interrupt 4
{
OS_ENTER_CRITICAL();
OSIntNesting++;
OS_EXIT_CRITICAL();
if(RI)
{
RI=0;
ReceiveBuf[length++]=SBUF; //接收串口数据
}
if(TI) //如果是发送中断
{
TI=0; //清除中断标志位
write_data(); //调用发送函数
}
OSIntExit();
}
加载中...
龙少飞天
3楼-- · 2019-03-25 00:58
/****************************************
串口接收中断
****************************************/
void UART_Receive(void) interrupt 4
{
OS_ENTER_CRITICAL();
OSIntNesting++;
OS_EXIT_CRITICAL();
if(RI)
{
RI=0;
ReceiveBuf[length++]=SBUF; //接收串口数据
}
if(TI) //如果是发送中断
{
TI=0; //清除中断标志位
write_data(); //调用发送函数
}
OSIntExit();
}
加载中...
一周热门
更多
>
相关问题
相关文章
基于51单片机的计算器设计
0个评论
51单片机300个proteus仿真实例下载
0个评论
51单片机 蜂鸣器
0个评论
51单片机驱动RC522模块
0个评论
基于51单片机的指纹密码锁
0个评论
AT89C51单片机制作简易密码锁
0个评论
51单片机汇编语言计数器
0个评论
51单片机精确延时设计
0个评论
×
关闭
采纳回答
向帮助了您的网友说句感谢的话吧!
非常感谢!
确 认
×
关闭
编辑标签
最多设置5个标签!
保存
关闭
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
关闭
您已邀请
15
人回答
查看邀请
擅长该话题的人
回答过该话题的人
我关注的人
{
static uchar send_length = sizeof(SendBuf); //这里把要发送的数据的长度定义为静态变量,用它来判断是否发送完
static uchar send_head=0;
if(send_length == 0) //如果无数据发送,就退出
{
//关闭串口中断
TI=0;
send_head=0;
return;
}
else
{
send_length--;
SBUF = SendBuf[send_head++];
}
}
/****************************************
串口接收中断
****************************************/
void UART_Receive(void) interrupt 4
{
if(RI)
{
RI=0;
// ReceiveBuf[length++]=SBUF; //接收串口数据
}
if(TI) //如果是发送中断
{
TI=0; //清除中断标志位
write_data(); //调用发送函数
TI = 1;
}
}
#define _UART_C
#include "includes.h"
static void write_data(void);
static INT8U send_length = 0; //这里把要发送的数据的长度定义为静态变量,
//用它来判断是否发送完,它的值在send_data函数中被赋值
//每次发送完一个字节,后在write_data中减一
/****************************************
串口初始化 9600bps 8bit 1stop
****************************************/
void Init_UART(void)
{
TMOD=0x20;
TH1=0xfd;
TL1=0xfd;
PCON=0x00;
SCON=0x50;
TR1=1;
ET1=0;
ES=1;
}
//串口发送十六进制数据
//num:要发送的数据的个数 *str:数据数组的首地址
//应用层调用此函数把要发送的数据写入发送缓冲器中。
void UART_SendData(unsigned char num,unsigned char *str)
{
INT8U i;
for(i=0;i<num;i++)
{
SendBuf=str;
}
send_length = i;
write_data(); //调用发送数据的函数
}
//串口发送字符串
void UART_SendString(unsigned char *str)
{
INT8U i=0;
while(str!=' ')
{
i++;
}
UART_SendData(i+1,str);
}
static void write_data(void)
{
static INT8U send_head=0;
if(send_length == 0) //如果无数据发送,就退出
{
//关闭串口中断
TI=0;
send_head=0;
// flag_uart = 0;
//发送信号量
OSSemPost(Sem_UART);
return;
}
else
{
send_length--;
// flag_uart = 1;
SBUF = SendBuf[send_head++];
}
}
/****************************************
串口接收中断
****************************************/
void UART_Receive(void) interrupt 4
{
OS_ENTER_CRITICAL();
OSIntNesting++;
OS_EXIT_CRITICAL();
if(RI)
{
RI=0;
ReceiveBuf[length++]=SBUF; //接收串口数据
}
if(TI) //如果是发送中断
{
TI=0; //清除中断标志位
write_data(); //调用发送函数
}
OSIntExit();
}
串口接收中断
****************************************/
void UART_Receive(void) interrupt 4
{
OS_ENTER_CRITICAL();
OSIntNesting++;
OS_EXIT_CRITICAL();
if(RI)
{
RI=0;
ReceiveBuf[length++]=SBUF; //接收串口数据
}
if(TI) //如果是发送中断
{
TI=0; //清除中断标志位
write_data(); //调用发送函数
}
OSIntExit();
}
一周热门 更多>