KEIL C51

#include<reg52.h>//包含文件#include<stdio.h>voidmain(void){SCON=0x20;TMOD=0x20;TH1=0xf3;T... #include <reg52.h> //包含文件
#include <stdio.h>
void main(void)
{ SCON=0x20;
TMOD=0x20;
TH1=0xf3;
TR1=1;
printf("HELLO I AM KEIL.\n");
printf("I will be yout friend.\n ") ;
}

编译都通过了,为什么我就看不到最后的那两行输出呢,在哪里可以看到,还是需要什么设置?
回答好的话加十分!!!!
照着你们说的程序输了一遍,可是在串口里只能看到几行的十六进制码,还是看不到最后的那两行输出,要怎么设置才能看到呢?
展开
 我来答
wjw111lu
2010-10-30 · TA获得超过114个赞
知道小有建树答主
回答量:151
采纳率:0%
帮助的人:176万
展开全部
初始化时要有TI=1,原因可以看下面的网络资料,还有定时器1要启动。至于看输出,debug时在view下有串口窗口,在串口中点右键,选择显示方式Terminal mode,如果是HEX mode就会显示16进制数。给你个参考程序。
#include<reg51.h>
#include<stdio.h>
void main()
{
SCON=0x50;
TMOD=0x20;
TCON=0x40;
TH1=0xe8;
TL1=0xe8;
TI=1;
TR1=1;
while(1)
{
printf("Hello World! \n");
}
}
以下资料为网络资料:
在keil中printf 默认是向串口中发送数据的,所以,如果应用该函数,必须先初始化串口,否则可能引起死机的情况,并且在printf之前应该先将TI置位,摘抄原因如下:

1.printf函数是调用putchar函数输入的,而putchar应该是先判断ti是否为1,不为1则等待为1。 如果为1则清0,然后送出一个字符。因此你如果直接使用printf函数,你的程序就会在putchar函数中等待ti为1。这时你的程序就相当于直接死掉了。你可以通过改写putchar函数实现自己的目的。TI相当于是初始化~不给赋初值就不干活
2.Keil的串口处理比较巧妙的,我的分析如下:
putchar.c里面,是先检测TI再发送。这样做的目的是把尽可能多的时间留给2次串口操作之间的程序,而不是把等待字节发送的时间白白空等待浪费掉。所以,在系统初始化的时候,一定要令TI=1; 就可以顺畅的使用printf函数了。搂主sbuf=" "的办法,其实就是令TI=1. 另外要特别注意,printf函数执行完毕后,最后一个字节并未发送完毕,例如在485通讯中,此时如果切换为收模式,会丢失最后一字节.

3.一般串口发送都是等TI(字节发送完标志)为1就马上发送下一字节,由于不管是中断还是查询TI标志的方法,都会检测TI,因此首次发送必须置位TI标志,使串口开始发送你的“在程序的初始化部分往串口数据寄存器SBUF里放一个字符来起用终端显示;”方法最终作用也就是把TI置1,改成TI=1;来启动发送也是一样的(当然,不会发出那个' '字符了)。

4.<stdio.h>中定义,调用底层的putchar()来实现.底层发送数据到串口时,先查TI=1是否成立,死等直到TI=1时将新数据写入SBUF,函数返回,所以要先将TI置1,启动第一次传输操作.可查看反汇编相关代码理解其工作机理!

5.自己理解:在多机通讯中,应该也要形成像 putchar()函数的机理,要有串口中断服务程序,并且是在该程序中判断TI,根据TI是不是该发送下一组数据~同样对于接收的一方..
hr101231841
2010-10-30 · 超过14用户采纳过TA的回答
知道答主
回答量:36
采纳率:0%
帮助的人:45.3万
展开全部
在最后加个死循环将程序挂起
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
道墨
2010-10-29 · TA获得超过1016个赞
知道大有可为答主
回答量:1152
采纳率:0%
帮助的人:1695万
展开全部
TI = 1;
即可看到输出,没有的话,打开view下的观察窗口看看
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式