版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、<p><b> 微機(jī)原理與匯編技術(shù)</b></p><p><b> 課程設(shè)計(jì)(論文)</b></p><p> 求100以內(nèi)素?cái)?shù)(2)</p><p> 起 止 時(shí) 間: 2015.12.21—2015.12.31</p><p> 課程設(shè)計(jì)(論文)任務(wù)及評(píng)語</p&g
2、t;<p> 院(系):電子與信息工程學(xué)院 教研室:計(jì)算機(jī)科學(xué)與技術(shù)</p><p> 注:平時(shí)成績占20%,答辯成績占40%,論文成績占40%。</p><p><b> 目 錄</b></p><p><b> 第1章 前言1</b></p><
3、;p><b> 1.1背景1</b></p><p> 1.2基本功能要求2</p><p> 第2章 程序設(shè)計(jì)3</p><p> 2.1題目的基本內(nèi)容3</p><p> 2.2 程序流程圖4</p><p> 2.3課程設(shè)計(jì)的具體內(nèi)容說明7</p>
4、<p> 2.4課程設(shè)計(jì)中關(guān)鍵內(nèi)容的分析設(shè)計(jì)說明8</p><p> 2.5運(yùn)行結(jié)果13</p><p> 第3章 課程設(shè)計(jì)總結(jié)16</p><p><b> 參考文獻(xiàn)17</b></p><p><b> 第1章 前言</b></p><p>
5、<b> 1.1背景</b></p><p> 匯編語言(assembly language)是一種用于電子計(jì)算機(jī)、微處理器、微控制器或其他可編程器件的低級(jí)語言,亦稱為符號(hào)語言。在匯編語言中,用助記符(Mnemonics)代替機(jī)器指令的操作碼,用地址符號(hào)(Symbol)或標(biāo)號(hào)(Label)代替指令或操作數(shù)的地址。在不同的設(shè)備中,匯編語言對(duì)應(yīng)著不同的機(jī)器語言指令集,通過匯編過程轉(zhuǎn)換成機(jī)器指
6、令。普遍地說,特定的匯編語言和特定的機(jī)器語言指令集是一一對(duì)應(yīng)的,不同平臺(tái)之間不可直接移植。</p><p> 許多匯編程序?yàn)槌绦蜷_發(fā)、匯編控制、輔助調(diào)試提供了額外的支持機(jī)制。有的匯編語言編程工具經(jīng)常會(huì)提供宏,它們也被稱為宏匯編器。</p><p> 匯編語言不像其他大多數(shù)的程序設(shè)計(jì)語言一樣被廣泛用于程序設(shè)計(jì)。在今天的實(shí)際應(yīng)用中,它通常被應(yīng)用在底層,硬件操作和高要求的程序優(yōu)化的場合。驅(qū)動(dòng)
7、程序、嵌入式操作系統(tǒng)和實(shí)時(shí)運(yùn)行程序都需要匯編語言。匯編語言的另一個(gè)特點(diǎn)就是它所操作的對(duì)象不是具體的數(shù)據(jù),而是寄存器或者存儲(chǔ)器,也就是說它是直接和寄存器和存儲(chǔ)器打交道,這也是為什么匯編語言的執(zhí)行速度要比其它語言快,但同時(shí)這也使編程更加復(fù)雜,因?yàn)榧热粩?shù)據(jù)是存放在寄存器或存儲(chǔ)器中,那么必然就存在著尋址方式,也就是用什么方法找到所需要的數(shù)據(jù)。例如上面的例子,我們就不能像高級(jí)語言一樣直接使用數(shù)據(jù),而是先要從相應(yīng)的寄存器AX、BX 中把數(shù)據(jù)取出。這
8、也就增加了編程的復(fù)雜性,因?yàn)樵诟呒?jí)語言中尋址這部分工作是由編譯系統(tǒng)來完成的,而在匯編語言中是由程序員自己來完成的,這無異增加了編程的復(fù)雜程度和程序的可讀性。</p><p><b> 1.2基本功能要求</b></p><p> 由于DOS的9號(hào)調(diào)用輸出的是ASCⅡ碼,因此我們?cè)谳敵龅狡聊坏臅r(shí)候一定要將其先轉(zhuǎn)換為ASCⅡ碼再使用9號(hào)調(diào)用輸出??紤]到ASCⅡ碼轉(zhuǎn)化為
9、數(shù)字較為麻煩,因此可以定義兩個(gè)組數(shù)據(jù)buf、buf1,其中buf用于存放1~99,buf1用于存放1~99的ASCⅡ碼。</p><p> 這段程序運(yùn)用的兩次loop循環(huán)分別實(shí)現(xiàn)把0~99送到buf、將0~99的ASCⅡ碼送到buf1。在循環(huán)完畢后,采用dos的9號(hào)調(diào)用將buf1的數(shù)據(jù)輸出到屏幕上,即1~99輸出到屏幕上。</p><p> 完成這段程序后,跳到下一個(gè)模塊,即刪除合數(shù)保
10、留素?cái)?shù)并顯示模塊。然后跳轉(zhuǎn)到下一模塊。求和,最后到求平均數(shù)模塊。</p><p><b> 第2章 程序設(shè)計(jì)</b></p><p> 2.1題目的基本內(nèi)容</p><p> 設(shè)計(jì)題目:求100以內(nèi)的素?cái)?shù)</p><p><b> 具體要求:</b></p><p>
11、 (1)求出這些素?cái)?shù)。</p><p> (2)在屏幕上顯示出求素?cái)?shù)的動(dòng)態(tài)過程(在屏幕上先顯示出100以內(nèi)的所有數(shù),再動(dòng)態(tài)地刪去不符合要求的數(shù),刪除的過程要明顯)。</p><p> ?。?)計(jì)算這些素?cái)?shù)的平均值(取整,四舍五入),以十進(jìn)制形式輸出,并讓改制以紅色顯示。</p><p> ?。?)數(shù)據(jù)的輸入和結(jié)果的輸出都要有必要的提示,且提示獨(dú)占一行。</
12、p><p><b> (5)要使用子程序</b></p><p><b> 2.2 程序流程圖</b></p><p> 圖2.1 顯示素?cái)?shù)程序流程圖</p><p> 圖2.2 刪除合數(shù)保留素?cái)?shù)程序流程圖</p><p> 圖2.3 求和程序流程圖</p>
13、<p> 圖2.4 求平均數(shù)程序流程圖</p><p> 2.3課程設(shè)計(jì)的具體內(nèi)容說明</p><p> 把0~99送到buf、將0~99的ASCⅡ碼送到buf1。在循環(huán)完畢后,采用dos的9號(hào)調(diào)用將buf1的數(shù)據(jù)輸出到屏幕上,即1~99輸出到屏幕上。</p><p><b> 算法描述:</b></p>&
14、lt;p> ?。?)開始,輸出素?cái)?shù)。</p><p> ?。?)判斷是否q退出,不退出則到(3)。</p><p> ?。?)按任意鍵繼續(xù)程序。</p><p> (4)輸出0-100全部數(shù)據(jù)。</p><p> (5)按任意鍵,每按一次刪除一個(gè)非素?cái)?shù)。</p><p> ?。?)刪除完畢,輸出平均數(shù)。<
15、;/p><p> ?。?)結(jié)束,退出程序。</p><p> 2.4課程設(shè)計(jì)中關(guān)鍵內(nèi)容的分析設(shè)計(jì)說明</p><p><b> 程序:</b></p><p> data segment</p><p> input1db 0ah,0dh,'if you want to qui
16、t,please press Q/q! '</p><p> db 0ah,0dh,'if you want to print 0~99,please press any other key!',0ah,0dh,' $'</p><p> input2 db 0ah,0dh,'if you want to quit,plea
17、se press Q/q! '</p><p> db 0ah,0dh,'if you want to find the prime number ,please press any other key!',0ah,0dh,0ah,0dh,'$'</p><p> input3db 0ah,0dh,'if you want to
18、quit,please press Q/q! '</p><p> db 0ah,0dh,'if you want to get the avreage of the prime numbers ,please press any other key!',0ah,0dh,0ah,0dh,'$'</p><p> input4db 0ah,0d
19、h,'the avreage of the prime numbers is:','$'</p><p> input5db 0ah,0dh,'press any key to quit!','$'</p><p> buf db 99 dup(?),0;用于存0~99</p><p&
20、gt; buf1 db 99 dup(?,?,','),0dh,0ah,'press any key to continue!',0dh,0ah,'$';用于放1~99的asc碼</p><p> buf2 db ?,?,0dh,0ah,'$'</p><p><b> data ends</b>
21、;</p><p> code segment</p><p> assume ds:data,cs:code</p><p> start:mov ax,data</p><p><b> mov ds,ax</b></p><p> lea dx,input1</p>
22、<p><b> mov ah,9</b></p><p><b> int 21h</b></p><p> mov ah,08h</p><p><b> int 21h</b></p><p> cmp al,'Q'</p>
23、<p><b> jE exit</b></p><p> cmp al,'q'</p><p> je exit</p><p> lea bx,buf</p><p><b> mov ax,0</b></p><p>&
24、lt;b> mov al,1</b></p><p><b> mov cx,99</b></p><p> loop1:mov [bx],al</p><p><b> inc al</b></p><p><b> inc bx</b><
25、/p><p> loop loop1</p><p><b> mov cx,99</b></p><p> lea si,buf1</p><p> lea bx,buf</p><p> loop2:mov ax,0</p><p> mov al,[bx]&l
26、t;/p><p><b> mov dl,10</b></p><p><b> div dl</b></p><p> add al,30h;十位asc碼</p><p> add ah,30h;個(gè)位asc碼</p><p> mov [si],al</p&
27、gt;<p> mov [si+1],ah</p><p><b> add si,3</b></p><p><b> add bx,1</b></p><p> loop loop2</p><p> lea dx,buf1</p><p><
28、;b> mov ah,9</b></p><p><b> int 21h</b></p><p> mov ah,08h</p><p> int 21h;顯示0~100</p><p><b> jmp bb</b></p><p>
29、 exit:mov ax,4c00h</p><p> int 21h;退出</p><p> bb:lea dx,input2</p><p><b> mov ah,9</b></p><p><b> int 21h</b></p><p> mo
30、v ah,08h</p><p><b> int 21h</b></p><p> cmp al,'Q'</p><p><b> jE exit</b></p><p> cmp al,'q'</p><p> je ex
31、it</p><p><b> mov cx,0</b></p><p> lea bx,buf</p><p> lea si,buf1</p><p> a1:mov dl,1</p><p> a2:and ax,0</p><p> mov al
32、,[bx+3]</p><p><b> dec al</b></p><p><b> inc dl</b></p><p><b> cmp al,dl</b></p><p><b> jz a3</b></p><p&g
33、t;<b> inc al</b></p><p><b> div dl</b></p><p><b> cmp ah,0</b></p><p><b> jnz a2</b></p><p> mov [si+9],ah</p>
34、;<p> mov [si+10],ah</p><p><b> jmp a4</b></p><p> a3:inc cx</p><p> a4:lea dx,buf1</p><p><b> mov ah,9</b></p><p>&l
35、t;b> int 21h</b></p><p> mov ah,08h</p><p><b> int 21h</b></p><p><b> add si,3</b></p><p><b> inc bx</b></p>&l
36、t;p> mov dl,[bx+3]</p><p> cmp dl,0 ;跳出循環(huán)</p><p><b> jnz a1</b></p><p> lea dx,input3</p><p><b> mov ah,9</b></p><p>&
37、lt;b> int 21h</b></p><p> mov ah,08h</p><p> int 21h;輸入提示</p><p> cmp al,'Q'</p><p><b> jE exit</b></p><p> cmp a
38、l,'q'</p><p> je exit</p><p><b> mov di,cx</b></p><p> add di,3;計(jì)數(shù)送到di</p><p><b> mov cx,99</b></p><p><b>
39、 and si,0</b></p><p> lea bx,buf1</p><p> loop3:mov al,[bx];十位</p><p> and ax,00ffh</p><p> mov dh,[bx+1];個(gè)位</p><p><b> cmp al,0<
40、;/b></p><p><b> jz c1</b></p><p> sub dh,30h</p><p> sub al,30h</p><p><b> mov dl,10</b></p><p><b> mul dl</b>&
41、lt;/p><p><b> add al,dh</b></p><p><b> add si,ax</b></p><p> c1:add bx,3</p><p> loop loop3</p><p> lea dx,input4</p><
42、;p><b> mov ah,9</b></p><p><b> int 21h</b></p><p> mov ah,08h</p><p><b> int 21h</b></p><p> mov ax,si;和送到ax</p>&l
43、t;p> mov bx,di;個(gè)數(shù)送到bx</p><p> and bx,00ffh</p><p><b> div bl</b></p><p><b> inc al</b></p><p> and ax,00ffh</p><p><b&
44、gt; mov bx,10</b></p><p> and bx,00ffh</p><p><b> div bl</b></p><p> add al,30h</p><p> add ah,30h;將平均值轉(zhuǎn)化為asc碼,al為十位,ah為個(gè)位</p><p>
45、 lea bx,buf2</p><p> mov [bx],al</p><p> mov [bx+1],ah</p><p> mov ah,09·</p><p><b> mov al,0</b></p><p><b> mov bh,00</b&g
46、t;</p><p><b> mov cx,2</b></p><p><b> mov bl,4</b></p><p><b> int 10h</b></p><p> lea dx,buf2</p><p><b> mov
47、 ah,9</b></p><p><b> int 21h</b></p><p> mov ah,08h</p><p><b> int 21h</b></p><p> lea dx,input5</p><p><b> mov ah
48、,9</b></p><p><b> int 21h</b></p><p> mov ah,08h</p><p><b> int 21h</b></p><p> exit1:mov ax,4c00h</p><p><b> int
49、21h</b></p><p><b> code ends</b></p><p><b> end start</b></p><p><b> 2.5運(yùn)行結(jié)果</b></p><p><b> 圖2.5 初始界面</b><
50、;/p><p> 圖2.6 顯示1~99</p><p> 圖2.7 選擇是否繼續(xù)求素?cái)?shù)</p><p> 圖2.8 動(dòng)態(tài)刪除合數(shù)保留素?cái)?shù)</p><p> 圖2.9 選擇是否求平均值</p><p> 圖2.10 將素?cái)?shù)平均值以紅色字輸出到屏幕</p><p> 第3章 課程設(shè)計(jì)總結(jié)&
51、lt;/p><p> 這次的微機(jī)原理課程設(shè)計(jì),求100以內(nèi)的素?cái)?shù),在數(shù)學(xué)的學(xué)習(xí)中,我們會(huì)經(jīng)常接觸到素?cái)?shù)這個(gè)概念。素?cái)?shù)又稱質(zhì)數(shù)。指在一個(gè)大于1的自然數(shù)中,除了1和此整數(shù)自身外,不能被其他自然數(shù)(不包括0)整除的數(shù)。因?yàn)楹蠑?shù)是由若干個(gè)質(zhì)數(shù)相乘而得來的,所以,沒有質(zhì)數(shù)就沒有合數(shù),由此可見素?cái)?shù)在數(shù)論中有著很重要的地位。比1大但不是素?cái)?shù)的數(shù)稱為合數(shù)。1和0既非素?cái)?shù)也非合數(shù)。這個(gè)學(xué)期我們剛好學(xué)了《微機(jī)原理與接口技術(shù)》這門課,并
52、且初步的了解了匯編語言知識(shí),并且可以編寫簡單的代碼。因此,我們可以運(yùn)用匯編語言來編寫程序,求取100以內(nèi)的素?cái)?shù),動(dòng)態(tài)的刪除合數(shù),并且以紅色的字輸出素?cái)?shù)的平均值。起初以為這個(gè)課題比較簡單,通過查書和資料可以很快做出來,結(jié)果開始做卻發(fā)現(xiàn)不是那么回事,發(fā)現(xiàn)了很多的問題。</p><p> 首先,課本上的知識(shí)還遠(yuǎn)遠(yuǎn)不夠,需要我借鑒別人的程序來提升自己對(duì)匯編語言的認(rèn)識(shí)以及了解,并且很多復(fù)雜難懂的程序還無法讀懂。其次,在編
53、寫的過程中,總會(huì)有各種各樣的問題出現(xiàn),即使一個(gè)小小的標(biāo)點(diǎn)符號(hào)錯(cuò)誤也無法將程序運(yùn)行出來,這就需要我們的耐心仔細(xì)去慢慢的調(diào)試并且發(fā)現(xiàn)錯(cuò)誤在哪里。第三,我們對(duì)于匯編語言的認(rèn)識(shí)還遠(yuǎn)遠(yuǎn)不夠,一學(xué)期的簡單學(xué)習(xí),應(yīng)用于編程還很吃力,dos調(diào)用、bios調(diào)用我們接觸的非常非常少??傊?,費(fèi)了九牛二虎之力,總算是解決這次的課程設(shè)計(jì)。</p><p> 這次課程設(shè)計(jì)給我?guī)淼氖斋@很多。第一,它讓我更進(jìn)一步的了解了匯編語言,并用其來做
54、一些實(shí)踐性的東西。第二,我在編寫和調(diào)試程序的時(shí)候,也鍛煉了我的耐心和細(xì)心。第三,這次課程設(shè)計(jì)也鍛煉了我查閱資料的能力。</p><p><b> 參考文獻(xiàn)</b></p><p> [1] 彭虎,周佩玲,傅忠謙.《微機(jī)原理與接口技術(shù)(第2版)》. 北京:電子工業(yè)出版社,2010年</p><p> [2] 李敬兆.《8086/8088和a
55、rm核匯編語言程序設(shè)計(jì)》.合肥:中國科技大學(xué)出版社.2000年</p><p> [3] 沈美明,溫冬嬋.《IBM—PC匯編語言程序設(shè)計(jì)(第二版)》.北京:清華大學(xué)出版社出版.2003年</p><p> [4] 沈美明,溫冬嬋,張赤紅.《IBM—PC 匯編語言程序設(shè)計(jì)實(shí)驗(yàn)教程》.北京:清華大學(xué)出版社出版.2003年 </p><p> [5] 楊立.《微機(jī)
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 微機(jī)原理與接口技術(shù)課程設(shè)計(jì)
- 微機(jī)原理與接口技術(shù)課程設(shè)計(jì)
- 微機(jī)原理與接口技術(shù)課程設(shè)計(jì)
- 微機(jī)原理與接口技術(shù)課程設(shè)計(jì).
- 微機(jī)原理與技術(shù)課程設(shè)計(jì)--步進(jìn)電機(jī)控制
- 微機(jī)原理與接口技術(shù)課程設(shè)計(jì)報(bào)告
- 微機(jī)原理及應(yīng)用技術(shù)課程設(shè)計(jì)
- 微機(jī)原理與接口技術(shù)課程設(shè)計(jì)--流水燈
- 微機(jī)原理與匯編語言課程設(shè)計(jì)
- 微機(jī)原理與接口技術(shù)課程設(shè)計(jì)-交通燈
- 紅外通信-微機(jī)原理與接口技術(shù)課程設(shè)計(jì)報(bào)告
- 微機(jī)原理與接口技術(shù)課程設(shè)計(jì) --存儲(chǔ)器
- 微機(jī)原理與接口技術(shù)課程設(shè)計(jì)報(bào)告書
- 電子表設(shè)計(jì)(微機(jī)原理與接口技術(shù)課程設(shè)計(jì))
- 微機(jī)原理與接口技術(shù)課程設(shè)計(jì)-----交通燈設(shè)計(jì)
- 微機(jī)原理與接口技術(shù)課程設(shè)計(jì)-數(shù)字式秒表
- 微機(jī)原理與接口技術(shù)課程設(shè)計(jì)報(bào)告——電子琴
- 微機(jī)原理與接口技術(shù)課程設(shè)計(jì)---智能搶答器
- 微機(jī)原理與接口技術(shù)課程設(shè)計(jì)---貪吃蛇游戲
- 單機(jī)微機(jī)原理與接口技術(shù)課程設(shè)計(jì)實(shí)驗(yàn)報(bào)告
評(píng)論
0/150
提交評(píng)論