一个60秒倒计时的程序,不知道哪里错了,求解答。

2019-07-15 22:52发布

#include<reg51.h>
#include<display.h>
#define uchar unsigned char
uchar p=0;
uchar second[2];
void Init_time0(void);
void main(void)
{
uchar i,s;
delayus(10);
Init_time0();
lcd_init();
s=60;
while(1)
{
  second[0]=s/10;
  second[1]=s%10;
  lcd_pos(0,0);
  for(i=0;i<2;i++)
  {
   lcd_wdat(second[i]+0x30);
  }
  lcd_wdat('s');
  while(p==200);
  p=0;
  if(s)
   s--;
}
}
void Init_time0(void)
{
TMOD|=0x01;
TH0=(65536-4068)/256;
TL0=(65536-4068)%256;
EA=1;
ET0=1;
TR0=1;
}
         
void time0()interrupt 1
{
TH0=(65536-4068)/256;
TL0=(65536-4068)%256;
p++;
}
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
7条回答
Loenity
1楼-- · 2019-07-16 04:26
if(s)  s--;这句当s减到0之后是不是就没得减了。
幻想乡
2楼-- · 2019-07-16 06:38
 精彩回答 2  元偷偷看……
Loenity
3楼-- · 2019-07-16 07:59
哦,对。不错,很聪明
rongshanlove
4楼-- · 2019-07-16 12:45
{:2:}{:2:}{:2:}{:2:}{:2:}
宋海波海之子
5楼-- · 2019-07-16 17:14
这个计时方法很有意思,不过还是像上面那哥们提的,变量s应该加一个判断
小兔崽子
6楼-- · 2019-07-16 17:40
程序思想还是比较好的,就是while(p==200);p=0;if(s) s--;这里有错以及编程思想不大好,建议改成 if(p==200){p=0;if(s) s--;}       不过,这个程序不适合加大比较大的工程里,建议再改进

一周热门 更多>