循環(huán)程序設計示例總結(jié)
當需要清0操作的字節(jié)單元的個數(shù)增加時,程序中MOV指令的個數(shù)也會隨之增加。為了降低程序中重復代碼的數(shù)量,縮短程序的長度,可以采用循環(huán)程序結(jié)構(gòu)進行程序設計。
【例3-64】編寫程序,將片內(nèi)RAM中地址為40H~7EH的存儲單元清0。
參考程序
由例3-64可知,如圖3-10所示,循環(huán)結(jié)構(gòu)程序由循環(huán)變量初始化、循環(huán)體、循環(huán)變量修改和循環(huán)結(jié)束控制等部分構(gòu)成。例3-64中兩個參考程序的主要差別是循環(huán)結(jié)束控制方式不同,參考程序1通過已知的循環(huán)次數(shù)控制程序結(jié)束,而參考程序2則通過循環(huán)結(jié)束條件控制循環(huán)次數(shù)。
圖3-10例3-64源程序的結(jié)構(gòu)劃分
另外,根據(jù)循環(huán)結(jié)束控制所處的位置,可以將循環(huán)程序分為直到型循環(huán)和當型循環(huán)。直到型循環(huán)先執(zhí)行循環(huán)體后進行循環(huán)結(jié)束條件的判斷,當型循環(huán)則與之相反,如圖3-11所示。
圖3-11直到型和當型循環(huán)結(jié)構(gòu)程序流程圖
a)直到型循環(huán)b)當型循環(huán)
若循環(huán)中嵌入循環(huán)則為多重循環(huán),否則為單重循環(huán),如例3-64的兩個參考程序均屬于單重循環(huán)程序。下面舉例說明單重循環(huán)和多重循環(huán)程序的設計方法。
1.單重循環(huán)程序
【例3-65】將片內(nèi)RAM中地址從60H開始的20H個單字節(jié)數(shù)據(jù)相加。要求:和為雙字節(jié)數(shù)據(jù),并按照由高字節(jié)到低字節(jié)的順序存放于片內(nèi)RAM的41H和40H單元中。
解:參考程序如下:
在該參考程序中,數(shù)據(jù)低字節(jié)加法不需要考慮進位,因此使用ADD指令;而低字節(jié)加法可能產(chǎn)生進位,且該進位必須加入到高字節(jié)的運算結(jié)果中,所以高字節(jié)加法應使用帶進位的加法指令ADDC。
【例3-66】將片外RAM中地址從1234H開始的20H個單字節(jié)分別存入片內(nèi)RAM中地址從50H開始的20H個字節(jié)單元中。
解:參考程序如下:
【例3-67】計算下面這段延時程序執(zhí)行一遍所需的時間,假設單片機晶振頻率為12MHz。
解:
1)單片機的機器周期是晶振周期的12倍,可得機器周期T=12/(12MHz)=1μs。
2)這是一個單重循環(huán)程序,第一條指令將0FFH送入R7后,第二條指令DJNZ將重復執(zhí)行R7次,即0FFH次,因此這段程序的執(zhí)行時間是所有指令的機器周期數(shù)乘以執(zhí)行次數(shù)再相加的和,即:1μs×1+2μs×0FFH=511μs=0.511ms。
3)被稱為延時程序是因為這樣的程序僅對所涉及的寄存器(或存儲單元)數(shù)據(jù)產(chǎn)生影響,并且執(zhí)行用時是可以計算的,在單片機系統(tǒng)程序中僅用于消耗時間。
4)若第一條指令將0送入R7,則該程序的執(zhí)行時間將達到最長,即:1μs×1+2μs×(0FFH+1)=513μs=0.513ms。
5)如果單片機晶振周期改為6MHz,則機器周期T=12/6MHz=2μs,該延時程序的執(zhí)行時間將加倍。
2.多重循環(huán)程序
【例3-70】計算下面這段延時程序執(zhí)行一遍所需的時間,假設單片機晶振頻率為12MHz。
解:
1)在此段程序中,例3-69的程序作為內(nèi)循環(huán)被嵌入另一個外循環(huán)中,外循環(huán)的次數(shù)為R6=14H。因此,內(nèi)循環(huán)指令將與外循環(huán)控制指令“DJNZ R6,DL”一起執(zhí)行14H次。
2)本程序為雙重循環(huán)程序,執(zhí)行的時間為:1μs×1+(511μs+2μs)×14H=10261μs。
【例3-71】片內(nèi)RAM中50H單元開始存有一個長度為N的字節(jié)型無符號數(shù)據(jù)塊,請將該數(shù)據(jù)塊中的數(shù)據(jù)按照由小到大的順序(即升序)重新排序。
解:參考程序如下:
該參考程序使用了“冒泡法”排序,該排序方法每次僅比較相鄰的兩個數(shù)(即第一個數(shù)與第二個數(shù)比較,第二個數(shù)與第三個數(shù)比較,依此類推),若不符合排序規(guī)則(本例中要求按從小到大排序),則交換這兩個數(shù)據(jù)。每輪排序?qū)⑺邢噜彽臄?shù)比較一遍后,最大數(shù)將被存入?yún)⑴c本輪排序的地址最大的存儲單元中,而且該存儲單元中的數(shù)將不參與下一輪排序。另外,本參考程序使用了兩條DJNZ指令,屬于雙重循環(huán)程序,內(nèi)、外循環(huán)次數(shù)分別由R6和R7控制。
特別需要注意,在設計循環(huán)程序時,為避免出現(xiàn)“死循環(huán)”(即循環(huán)體執(zhí)行無限次),必須遵循以下設計原則:
1)不能從循環(huán)體外直接跳入循環(huán)體內(nèi)。
2)不能從外循環(huán)直接跳入內(nèi)循環(huán)。
3)內(nèi)、外循環(huán)不能相互交叉。