微机原理与接口技术实验:宏实现1+2+3...+100
生活随笔
收集整理的這篇文章主要介紹了
微机原理与接口技术实验:宏实现1+2+3...+100
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
學(xué)生實(shí)驗(yàn)報(bào)告
實(shí)驗(yàn)課名稱:微機(jī)原理與接口技術(shù)
實(shí)驗(yàn)項(xiàng)目名稱:宏
實(shí)驗(yàn)名稱:宏實(shí)現(xiàn)1+2+3…+100
一、 實(shí)驗(yàn)?zāi)康?/h2>
掌握重復(fù)宏的簡(jiǎn)單使用,并實(shí)現(xiàn)1+2+3…+100
二、實(shí)驗(yàn)內(nèi)容
設(shè)計(jì)一個(gè)程序,利用重復(fù)宏,實(shí)現(xiàn)1+2+3…+100,并將結(jié)果5050顯示在電腦屏幕上
三、實(shí)驗(yàn)儀器與設(shè)備
計(jì)算機(jī),DOSbox虛擬機(jī),外接設(shè)備
四、實(shí)驗(yàn)原理
利用宏的定義,常用的DOS命令,計(jì)算1+2+3…+100
五、實(shí)驗(yàn)過程與代碼
stack segment dw 521 dup(?) ;申請(qǐng)棧空間 為保護(hù)變量使用 stack endsdata segment string db 'hell,everybody',0dh,0ah,'$' table equ this byte ;存儲(chǔ)單元?jiǎng)e名操作符THIS:它為同一存儲(chǔ)單元取另一別名-table,該別名可具有其自身的數(shù)據(jù)屬性,但其段地址和偏移量是不變的count=1rept 100 db count ;重復(fù)匯編 count=count+1 endmdata endscode segment assume cs:code,ds:data,ss:stackstart: mov ax,data mov ds,axmov dx,offset string ;顯示 字符串 hello world mov ah,9 int 21hmov ax,0 mov si,offset table mov cx,100;開始循環(huán)累加 sum: add al,[si] adc ah,0 inc si loop summov dx,0 mov cx,1000 div cx push dx ;這里很重要 利用棧保護(hù)dx的值 不然 后面add dl,30h后 會(huì)破壞原來(lái)dx的值 而dx的值是余數(shù) 不可以被破壞 mov dl,al add dl,30h mov ah,02h int 21h pop dx ;恢復(fù)dx的值;提取百位 mov ax,dx mov cl,100 div cl mov dl,al add dl,30h mov ch,ahmov ah,02h int 21h;提取十位 mov al,ch mov ah,0 mov cl,10 div clmov ch,ah mov dl,al add dl,30h mov ah,02h int 21hmov dl,ch add dl,30h mov ah,02 int 21hjieshu: mov ax,4c00h int 21h code ends end start六、實(shí)驗(yàn)結(jié)果與分析
????????通過本次實(shí)驗(yàn),學(xué)會(huì)了宏的簡(jiǎn)單使用,理解了宏和子程序的區(qū)別。實(shí)驗(yàn)中印象最深的是累加求和,必須考慮到進(jìn)位問題,不可以直接求和。同時(shí)還有匯編語(yǔ)言中,對(duì)一些寄存器的值,進(jìn)行的保護(hù)操作,匯編不同與其他編程語(yǔ)言,用來(lái)存儲(chǔ)變量的寄存器很少,在這種情況下,我們應(yīng)該及時(shí)做好變量的保護(hù)措施。
總結(jié)
以上是生活随笔為你收集整理的微机原理与接口技术实验:宏实现1+2+3...+100的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Java中的JavaCore/HeapD
- 下一篇: Python再次拿第一,我一点都不意外,