中文字幕 另类精品,亚洲欧美一区二区蜜桃,日本在线精品视频免费,孩交精品乱子片免费

<sup id="3hn2b"></sup>

    1. <sub id="3hn2b"><ol id="3hn2b"></ol></sub><legend id="3hn2b"></legend>

      1. <xmp id="3hn2b"></xmp>

      2. 新聞中心

        EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > 51單片機延時程序的設計方法

        51單片機延時程序的設計方法

        作者: 時間:2012-07-19 來源:網(wǎng)絡 收藏

        其生成的代碼是一樣的。不過這的確不是什么好的習慣。因為這里實在沒有必要再引入多余的變量。我們繼續(xù)討論正題。有的朋友為了得當更長的延時,甚至用了這樣的代碼:
        void delay2(unsigned long i)
        {
        for(; i != 0; i--);
        }
        這段代碼產(chǎn)生的匯編代碼是什么樣子的?其實不用想也知道它是如何恐怖的$#^%%$......讓我們看一看:
        ; FUNCTION _delay2 (BEGIN)
        ; SOURCE LINE # 18
        0000 8F00 R MOV i+03H,R7
        0002 8E00 R MOV i+02H,R6
        0004 8D00 R MOV i+01H,R5
        0006 8C00 R MOV i,R4
        ; SOURCE LINE # 19
        ; SOURCE LINE # 20
        0008 ?C0007:
        0008 E4 CLR A
        0009 FF MOV R7,A
        000A FE MOV R6,A
        000B FD MOV R5,A
        000C FC MOV R4,A
        000D AB00 R MOV R3,i+03H
        000F AA00 R MOV R2,i+02H
        0011 A900 R MOV R1,i+01H
        0013 A800 R MOV R0,i
        0015 C3 CLR C
        0016 120000 E LCALL ?C?ULCMP
        0019 601A JZ ?C0010
        001B E500 R MOV A,i+03H
        001D 24FF ADD A,#0FFH
        001F F500 R MOV i+03H,A
        0021 E500 R MOV A,i+02H
        0023 34FF ADDC A,#0FFH
        0025 F500 R MOV i+02H,A
        0027 E500 R MOV A,i+01H
        0029 34FF ADDC A,#0FFH
        002B F500 R MOV i+01H,A
        002D E500 R MOV A,i
        002F 34FF ADDC A,#0FFH
        0031 F500 R MOV i,A
        0033 80D3 SJMP ?C0007
        ; SOURCE LINE # 21
        0035 ?C0010:
        0035 22 RET
        ; FUNCTION _delay2 (END)
        呵呵,這倒是的確可以延遲很長時間~~~但是毫無精度可言了。
        那么,用C到底能不能實現(xiàn)精確的延時呢?我把代碼稍微改了一下:
        void delay1(unsigned char i)
        {
        while(i--);
        }
        因為根據(jù)經(jīng)驗,越簡潔的C代碼往往也能得出越簡潔的機器代碼。那這樣結果如何呢?把它生成的匯編代碼拿出來看一看就知道了。滿懷希望的我按下了“Build target”鍵,結果打擊是巨大的:
        ; FUNCTION _delay1 (BEGIN)
        ; SOURCE LINE # 13
        ;---- Variable i assigned to Register R7 ----
        ; SOURCE LINE # 14
        0000 ?C0004:
        ; SOURCE LINE # 15
        0000 AE07 MOV R6,AR7
        0002 1F DEC R7
        0003 EE MOV A,R6
        0004 70FA JNZ ?C0004
        ; SOURCE LINE # 16
        0006 ?C0006:
        0006 22 RET
        ; FUNCTION _delay1 (END)
        雖說生成的代碼跟用for語句是不大一樣,不過我可以毫無疑問的說,這兩種方法的效率是一樣的。似乎到此為止了,因為我實在想不出來源程序還有什么簡化的余地??磥砦揖鸵贸鰜磉@個結論了:“如果需要us級的延時精度,需要時用匯編語言?!钡钦娴氖沁@樣嗎?我還是不甘心。因為我不相信大名鼎鼎的 Keil C 編譯器居然連 djnz 都不會用???因為實際上程序體里只需要一句 loop: djnz r7, loop。近乎絕望之際(往往人在這種情況下確可以爆發(fā)出來,哦呵呵呵~~~),我隨手改了一下:
        void delay1(unsigned char i)
        {
        while(--i);
        }
        心不在焉的編譯,看源碼:
        ; FUNCTION _delay1 (BEGIN)
        ; SOURCE LINE # 13
        ;---- Variable i assigned to Register R7 ----
        ; SOURCE LINE # 14
        0000 ?C0004:
        ; SOURCE LINE # 15
        0000 DFFE DJNZ R7,?C0004
        ; SOURCE LINE # 16
        0002 ?C0006:
        0002 22 RET
        ; FUNCTION _delay1 (END)
        天~~~奇跡出現(xiàn)了......我想這個程序應該已經(jīng)可以滿足一般情況下的需要了。如果列個表格的話:
        i delay time/us
        1 5
        2 7
        3 9
        ...
        計算延時時間時,已經(jīng)算上了調(diào)用函數(shù)的lcall語句所花的2個時鐘周期的時間。

        51單片機相關文章:51單片機教程


        單片機相關文章:單片機教程


        單片機相關文章:單片機視頻教程


        單片機相關文章:單片機工作原理


        晶振相關文章:晶振原理

        上一頁 1 2 下一頁

        評論


        相關推薦

        技術專區(qū)

        關閉