2023年全國碩士研究生考試考研英語一試題真題(含答案詳解+作文范文)_第1頁
已閱讀1頁,還剩19頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(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ì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論