1、使用工具 代碼編寫:NotePad++,代碼編譯器:MASM 2、一個源程式從寫出到執行的過程 第一步,使用文本編輯器,用彙編語言編寫彙編源程式,這一步產生一個存儲源程式的文本文件。 第二步,對源程式進行編譯,連接。使用MASM.exe對源程式文件進行編譯,產生目標文件,再使用LINK.exe對 ...
1、使用工具 代碼編寫:NotePad++,代碼編譯器:MASM 2、一個源程式從寫出到執行的過程 第一步,使用文本編輯器,用彙編語言編寫彙編源程式,這一步產生一個存儲源程式的文本文件。 第二步,對源程式進行編譯,連接。使用MASM.exe對源程式文件進行編譯,產生目標文件,再使用LINK.exe對目標文件進行連接,生成可在操作系統中直接運行的可執行文件。可執行文件包括兩個部分,程式(從源程式的彙編指令翻譯過來的機器碼)和數據(源程式中定義的數據);相關的描述信息 (程式有多大,要占多少記憶體空間)。這一步產生了一個可在操作系統中直接運行的可執行文件.exe。 第三部,執行可執行文件。操作系統依照可執行文件中的描述信息,將可執行文件中的機器碼和數據載入到記憶體,併進行相關的初始化,比如講CS:IP指向第一條要執行的彙編指令。然後由CPU執行程式。 3、一段簡單的彙編語言源程式 assume CS:codesg codesg segment mov ax,0123H mov bx,0456H add ax,bx add ax,ax mov ax,4C00H int 21H codesg ends end 上面的代碼就是簡單的加法運算,這裡要解釋幾個概念。 第一,偽指令。彙編語言源程式中包含了彙編指令和偽指令。彙編指令會被翻譯成對應的機器碼,而偽指令則沒有對應的機器碼,最終不能被CPU所理解,但是會被編譯器理解。偽指令是被編譯器編譯的指令,編譯器根據偽指令進行相關的編譯工作。在上面的程式中,偽指令有assume,segment...ends,end。 (1)segment...ends segment和ends是成對出現的偽指令。意思是在二者之間定義一個段,segment表示一個段的開始,ends表示一個段的結束: 段名segment . . 段名 ends 一個彙編程式可以由多個段組成,這些段被用來存放代碼、數據、或者被當做一個棧空間來使用。 (2)end end是一個彙編程式結束的標記,編譯器在編譯程式時,碰到了偽指令的話,就會停止對源程式的編譯。所以程式寫完了一定要加上偽指令end。 (3)assume assume表示“假設”的意思,假設某一段寄存器和程式中的某一個段相關聯,也就是告訴CPU指向哪一個段,從哪裡開始執行彙編指令的意思。 上面的代碼中codesg segment...codesg ends定義了一個名為codesg的段,在這個段中存放了代碼,所以這個段是一個代碼段。程式開頭用assume cs:codesg將代 碼段codesg和CPU中的段寄存器CS聯繫在一起。 4、源程式中的“程式” 用彙編語言編寫的程式包括偽指令和彙編指令。彙編指令是最終由電腦執行的程式,偽指令只是由編譯器來執行。所以說,源程式中的“程式”指的就是由彙編指令或者數據構成的。程式經過編譯連接後轉換為CPU認識的機器碼,過程如下圖所示:
5、標號 彙編程式中,除了彙編指令和偽指令外,還有一些標號。就像是上面的示例代碼中的“codesg”。一個標號指代了一個地址。比如codesg在segment前,作為段的名稱,這個段的名 稱最終被編譯、連接程式處理為一個段的段地址。 6、程式返回 在上面的示例代碼中: mov ax,4c00H int 21H 這兩條指令所實現的功能就是程式返回。在程式的末尾使用這兩條指令就可以實現程式返回。 這裡我們要理解什麼是程式返回。在DOS單任務操作系統中,一次只能運行一個程式,當程式1在運行時,程式2要運行,則要將CPU的控制權給程式2,程式2才能得到運行。程 序2開始運行後,程式1暫停。當程式2運行完畢後,應該講CPU的控制權交還給程式1,此後,程式1繼續運行。所以,一個程式結束後,將CPU的控制權交還給使得這個程式得 以運行的程式,這個過程就是程式返回。 7、區分與“結束”相關的概念 這裡我們已經瞭解了幾個“結束”相關的概念,區分如下表所示:
8、編譯源程式 首先我們要有一個彙編編譯器,這裡我們使用的是MASM,需要下載的話,可以去我的百度網盤下載,鏈接:http://pan.baidu.com/s/1dFMUgH7(密碼:xdpm) 將源程式文件和編譯器放一塊兒,方便我們直接編譯:
進入cmd小黑窗,進入到MASM編譯器目錄中,運行MASM.exe: 此時文件夾中會出現一個object文件:
接下來我們使用LINK.exe來連接這個object文件:
連接後,文件夾中就會出現一個可執行文件: 要想查看程式的運行過程,我們可以使用debug來單步調試這個可執行程式: 我們可以看到,使用t命令單步執行debug後,會運行我們在程式中寫的彙編指令。這裡我們要註意一點,就是當語句執行到最後一局“int 21”時,我們要使用P命令來結束。調試結 束後,按“q”來退出debug,回到command中。 9、小結 彙編程式從寫出到執行的過程如下圖所示: