欧美极品高清xxxxhd,国产日产欧美最新,无码AV国产东京热AV无码,国产精品人与动性XXX,国产传媒亚洲综合一区二区,四库影院永久国产精品,毛片免费免费高清视频,福利所导航夜趣136

標題: 新手請教用單片機定時器中斷方法實現(xiàn)數(shù)碼管顯示出現(xiàn)的問題 [打印本頁]

作者: jiacai    時間: 2019-9-10 06:00
標題: 新手請教用單片機定時器中斷方法實現(xiàn)數(shù)碼管顯示出現(xiàn)的問題
請大佬們幫我看看下面這程序那里出了問題。
程序想要實現(xiàn)的是用定時器中斷方式實現(xiàn)數(shù)碼管動態(tài)顯示。實現(xiàn)六個數(shù)碼管顯示0~999999,從000000開始沒隔1s數(shù)碼管+1。中斷是1ms,每中斷一次刷新一次數(shù)碼管?墒俏野殉绦驘M開發(fā)板所實現(xiàn)的現(xiàn)象是每進入一次中斷數(shù)碼管數(shù)據(jù)就會加1,并不是1s加1。查了好久弄不明白是什么原因。


#include <reg52.h>
#include <intrins.h>
#define uchar unsigned char
#define uint unsigned int
        
sbit dule=P2^6;
sbit wele=P2^7;

uchar code wetable[]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f};   //數(shù)碼管位選
uchar code dutable[]={
0x3f,0x06,0x5b,0x4f,
0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,
0x39,0x5e,0x79,0x71,0x00};   //段選

uchar ledbuff[6]={0x00,0x00,0x00,0x00,0x00,0x00};  //暫存
uchar flag1s=0;   //1s標志
uchar i=0;
uint cnt=0;
unsigned long sec=0;
void main()
{

        dule=0;
        wele=0;

        TH0=0xfc;
        TL0=0x67;
        EA=1;
        ET0=1;
        TR0=1;
        
        while(1)
        {
                if(cnt==1000)
        {
                cnt=0;
                flag1s=1;
        }
                if(flag1s==1)
                {
                        flag1s=0;
                        sec++;
                        ledbuff[0]=dutable[sec%10];
                        ledbuff[1]=dutable[sec/10%10];
                        ledbuff[2]=dutable[sec/100%10];
                        ledbuff[3]=dutable[sec/1000%10];
                        ledbuff[4]=dutable[sec/10000%10];
                        ledbuff[5]=dutable[sec/100000%10];
                }
        }
}

void timer0() interrupt 1  
{
        

        TH0=0xfc;     
        TL0=0x67;
        
        switch(i)
                {
                        case 0:i++;P0=ledbuff[0];dule=1;dule=0;_nop_();P0=wetable[7];wele=1;wele=0;break;
                        case 1:i++;P0=ledbuff[1];dule=1;dule=0;_nop_();P0=wetable[6];wele=1;wele=0;break;
                        case 2:i++;P0=ledbuff[2];dule=1;dule=0;_nop_();P0=wetable[5];wele=1;wele=0;break;
                        case 3:i++;P0=ledbuff[3];dule=1;dule=0;_nop_();P0=wetable[4];wele=1;wele=0;break;
                        case 4:i++;P0=ledbuff[4];dule=1;dule=0;_nop_();P0=wetable[3];wele=1;wele=0;break;
                        case 5:i=0;P0=ledbuff[5];dule=1;dule=0;_nop_();P0=wetable[2];wele=1;wele=0;break;
                        default:break;
                }
                cnt++;
}


作者: tyrl800    時間: 2019-9-10 18:21
用到鎖存器分時輸出段碼和位碼,鎖存信號有問題

作者: wulin    時間: 2019-9-10 22:07
給你改一下,你試試。
  1. #include <reg52.h>
  2. #include <intrins.h>
  3. #define uchar unsigned char
  4. #define uint unsigned int
  5.         
  6. sbit dule=P2^6;
  7. sbit wele=P2^7;

  8. uchar code wetable[]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f};   //數(shù)碼管位選
  9. uchar code dutable[]={
  10. 0x3f,0x06,0x5b,0x4f,
  11. 0x66,0x6d,0x7d,0x07,
  12. 0x7f,0x6f,0x77,0x7c,
  13. 0x39,0x5e,0x79,0x71,0x00};   //段選

  14. uchar ledbuff[6]={0x00,0x00,0x00,0x00,0x00,0x00};  //暫存
  15. uchar flag1s=0;   //1s標志
  16. uchar i=0;
  17. uint cnt=0;
  18. unsigned long sec=0;
  19. void main()
  20. {
  21.         dule=0;
  22.         wele=0;
  23.         TMOD=0x01;
  24.         TH0=0xfc;
  25.         TL0=0x66;
  26.         EA=1;
  27.         ET0=1;
  28.         TR0=1;       
  29.         while(1)
  30.         {
  31.                 if(flag1s==1)
  32.                 {
  33.                         flag1s=0;
  34.                         sec++;
  35.                         if(sec>999999)
  36.                                 sec=0;
  37.                         ledbuff[0]=dutable[sec%10];
  38.                         ledbuff[1]=dutable[sec/10%10];
  39.                         ledbuff[2]=dutable[sec/100%10];
  40.                         ledbuff[3]=dutable[sec/1000%10];
  41.                         ledbuff[4]=dutable[sec/10000%10];
  42.                         ledbuff[5]=dutable[sec/100000%10];
  43.                 }
  44.         }
  45. }

  46. void timer0() interrupt 1  
  47. {
  48.         TH0=0xfc;     
  49.         TL0=0x67;
  50.         P0=0x00;//消隱
  51.         dule=1;
  52.         dule=0;
  53.         switch(i)
  54.         {
  55.                 case 0:P0=wetable[5];wele=1;wele=0;P0=ledbuff[0];dule=1;dule=0;i++;break;
  56.                 case 1:P0=wetable[4];wele=1;wele=0;P0=ledbuff[1];dule=1;dule=0;i++;break;
  57.                 case 2:P0=wetable[3];wele=1;wele=0;P0=ledbuff[2];dule=1;dule=0;i++;break;
  58.                 case 3:P0=wetable[2];wele=1;wele=0;P0=ledbuff[3];dule=1;dule=0;i++;break;
  59.                 case 4:P0=wetable[1];wele=1;wele=0;P0=ledbuff[4];dule=1;dule=0;i++;break;
  60.                 case 5:P0=wetable[0];wele=1;wele=0;P0=ledbuff[5];dule=1;dule=0;i=0;break;
  61.                 default:break;
  62.         }
  63.         cnt++;
  64.         if(cnt>=1000)
  65.         {
  66.                 cnt=0;
  67.                 flag1s=1;
  68.         }
  69. }

復制代碼

作者: csmyldl    時間: 2019-9-11 00:13
程序是沒有問題的,只是定時計數(shù)器的計時未算準確而已,如果你是用51單片機,在TH0=0xfc;
        TL0=0x67;語句前還得說明定時方式,如TMOD=0x01;程序中沒有說明,默認是方式0,那你裝載的TH0 TL0是不是有問題,試著把if(cnt==1000)這一條改為if(cnt==8000),如果秒鐘變化變慢,就說明程序是沒有問題的
作者: jiacai    時間: 2019-9-11 01:28
tyrl800 發(fā)表于 2019-9-10 18:21
用到鎖存器分時輸出段碼和位碼,鎖存信號有問題

那這一段該怎么決絕呢?
作者: jiacai    時間: 2019-9-12 02:32
wulin 發(fā)表于 2019-9-10 22:07
給你改一下,你試試。

我燒寫試了,完美解決。  連抖動鬼影的問題都解決了太棒了。我得好好去理解

非常感謝!!
作者: jiacai    時間: 2019-9-12 02:38
csmyldl 發(fā)表于 2019-9-11 00:13
程序是沒有問題的,只是定時計數(shù)器的計時未算準確而已,如果你是用51單片機,在TH0=0xfc;
        TL0=0x67; ...

非常感謝。
有位朋友幫我修改了下解決了問題。接下來去好好理解下以及按你說的方法驗證。謝謝
作者: jiacai    時間: 2019-9-12 02:39
wulin 發(fā)表于 2019-9-10 22:07
給你改一下,你試試。

我燒寫試了,完美解決。  連抖動鬼影的問題都解決了太棒了。我得好好去理解

非常感謝。
作者: jiacai    時間: 2019-9-12 02:40
感謝大家的幫助




歡迎光臨 (http://www.raoushi.com/bbs/) Powered by Discuz! X3.1