《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 解決方案 > 匯編基礎:順序、分支與循環程序設計

匯編基礎:順序、分支與循環程序設計

2017-06-10
關鍵詞: 匯編

一個算法用程序設計語言的語句有序地組合在一起加以描述,其組合方式稱為程序的控制結構或簡稱為程序結構。程序的基本結構形式有順序結構、分支結構和循環結構。

一、順序結構

順序結構是最簡單的,也是最基本的程序結構形式,這種結構形式的程序的最大特點就是程序運行時從開始到結尾一直是按照編寫指令的順序執行,且每條指令僅執行一次,具有順序結構的程序或者程序段,成為順序程序。

我們拿一個簡單的程序來說明匯編的順序程序設計。

例:設兩個字存儲變量X和Y, 編程實現這兩個變量的交換。

分析:由于存儲單元之間不能夠直接進行數據交換,所以利用通用寄存器AX來作為交換的中介。我在這里給出一個代碼范例:

DATA    SEGMENT    
   X   DW  1032H    
   Y   DW  2043H    
DATA    ENDS    
STACK1  SEGMENT PARA STACK    
   DW   20H   DUP (0)    
STACK1  ENDS    
CODE    SEGMENT    
ASSUME CS:CODE, DS:DATA, SS:STACK1    
BEGIN:  MOV     AX, DATA    
   MOV     DS, AX    
   MOV AX, X    
   XCHG    AX, Y    
   MOV X, AX    
   MOV AH, 4CH    
   INT 21H    
CODE    ENDS    
   END

代碼分析:前面一部分是對數據以及堆棧的定義,這里我就不再多說了,我們從BEGIN開始,因為對于MOV來說,不能夠直接將DATA作為源操作數,DS作為目的操作數,所以要通過一個通用寄存器來實現兩者之間的賦值,MOV   AX, X意為將X的值先保存在AX中,而后執行XCHG AX, Y將AX與Y的值進行交換,此時Y里面存儲的便是X的值,AX中存儲的Y的值。緊接著MOV X, AX再將AX中存儲的Y的值賦予X,即實現X與Y值得交換。

二、分支程序設計

實現分支程序需要有相應的轉移指令的支持,而轉移指令又分為無條件轉移指令與有條件轉移指令兩類,在有條件轉移指令中,不同的條件往往是通過標志寄存器中條件標志的不同狀態反映的。因而,分支程序設計中一個至關重要的問題是如何根據標志寄存器中標志位的不同狀態,配合使用合適的轉移指令實現程序的轉移。關于轉移指令請看我的另一篇文(http://yiluohuanghun.blog.51cto.com/3407300/940123)。

還是拿例子來說吧:X為存儲單元中的有符號字數據,編寫程序實現計算其絕對值,并保存到原處。

分析:當X>=0時,X的絕對值就是它本身,否則利用求負指令將X變號,并放回要原處,下面我給出了一個程序,大家可以參考下:

DATA    SEGMENT    
   X   DW  0F874H    
DATA    ENDS    
STACK1  SEGMENT PARA    STACK    
   DW  20H DUP  (0)    
STACK1  ENDS    
CODE    SEGMENT    
ASSUME  CS:CODE, DS:DATA, SS:STACK1    
BEGIN:  MOV AX, DATA    
   MOV DS, AX    
   MOV AX, X    
   TEST    AX, AX      
   JNS DONE    
   NEG X   ;負指令NEG對X取反    
DONE:   MOV AH, 4CH    
   INT 21H    
CODE    ENDS    
   END BEGIN

程序分析:TESTAX, AX;此處目的是為了重置標志寄存器各位的值,以便于下一條指令JNS使用標志寄存器

三、循環程序設計

在進行循環程序設計之前同分支程序設計一樣,都要先知道一個基本控制指令,對于循環控制指令有如下4大類:

1、LOOPTARGET

執行的操作:先將CX<-(CX)-1,如果(CX)不等于0,則將IP指向TARGET的偏移量

2、LOOPZ/LOOPETARGET

執行操作:先將CX<-(CX)-1,如果(CX)不等于0并且ZF=1,則將IP指向TARGET的偏移量

3、LOOPNZ/LOOPNE   TARGET

執行操作:先將CX<-(CX)-1,如果(CX)不等于0并且ZF不等于1,則將IP指向TARGET的偏移

4、JCXZTARGET

執行操作:測試(CX)是否0,但不對CX寄存器進行修改,如果(CX)=0,那么IP指向TARGET的偏移量

下面還是以實例來說明問題:數據段的ARY數組中存放有10個無符號數,試找出其中最大者送入MAX單元。

分析:首先將數組中的第一個數取出放入AL,然后依次與數組中的其他元素進行比較,將較大者放入AL中,遍歷數組后,AL中存放的就是最大的數。具體實現過成功如下:

DATA    SEGMENT    
   ARY DB  17, 5, 40, 0, 67, 12, 34, 78, 32, 10    
   MAX DB  ?    
DATA    ENDS    
STACK1  SEGMENT PARA    STACK    
   DW  20H DUP  (0)    
STACK1  ENDS    
CODE    SEGMENT    
ASSUME  CS:CODE, SS:STACK1, DS:DATA    
BEGIN:  MOV AX, DATA    
   MOV DS, AX    
   MOV SI, OFFSET  ARY ;SI指向ARY的第一個元素    
   MOV CX, 9       ;CX作循環次數計數    
   MOV AL, [SI]        ;取第一個元素到AL    
LOP:    INC SI      ;SI指向后一個元素    
   CMP AL, [SI]        ;比較兩個數    
   JAE BIGER       ;前一個元素大于后一個元素時轉移    
   MOV AL, [SI]        ;取較大數到AL    
BIGER:  LOOP    LOP     ;(CX)不等于0 則轉移    
   MOV MAX, AL    
   MOV AH, 4CH    
   INT 21H    
CODE    ENDS    
   END BEGIN

以上就介紹著三種程序設計方式。


本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
主站蜘蛛池模板: 国产欧美精品一区二区三区四区 | 久久一日本道色综合久 | 欧美一级毛片一级毛片 | 精品国产不卡一区二区三区 | 三级网站视频在线观看 | 国产午夜视频 | 一级做a爰片久久毛片美女 一级做a爰片久久毛片免费看 | 国产愉拍精品手机 | 成人a毛片高清视频 | 中文字幕日韩精品中文区 | 精品国产日韩亚洲一区在线 | a大片久久爱一级 | 日韩欧美在线观看视频一区二区 | 农村寡妇野外情一级毛片 | 亚洲国产综合人成综合网站00 | 精品香蕉99久久久久网站 | 成人国产在线视频在线观看 | 青木玲中文字幕一区二区 | 91精品国产薄丝高跟在线看 | 一本色道久久综合 | 午夜一级影院 | 欧美一区欧美二区 | 草草免费观看视频在线 | 免费国产a国产片高清 | 久久国产免费观看精品1 | 国产一级aaa全黄毛片 | 在线中文字幕亚洲 | 亚洲精品在线免费观看视频 | 中文字幕av一区二区三区 | 国产夫妇精品自在线 | 99国产精品久久久久久久日本 | 国产成人在线网址 | 5388国产亚洲欧美在线观看 | 欧美一级毛片免费网站 | 欧美男人操女人 | 韩国一级黄色毛片 | 国产精品久久久久久久久免费观看 | 久久久久国产精品 | 国产精品免费精品自在线观看 | 日韩毛片欧美一级a网站 | 九九热精 |