1. <tt id="5hhch"><source id="5hhch"></source></tt>
    1. <xmp id="5hhch"></xmp>

  2. <xmp id="5hhch"><rt id="5hhch"></rt></xmp>

    <rp id="5hhch"></rp>
        <dfn id="5hhch"></dfn>

      1. 偽指令EVEN操作機理的問題分析論文

        時間:2024-05-30 13:57:20 其他類論文 我要投稿

        關于匯編偽指令EVEN操作機理的問題分析論文

          匯編語言屬于低級語言范疇,是一種面向機器的、功能很強的程序設計語言。它具有目標代碼簡短,占用內存少,執行速度快等優點。

        關于匯編偽指令EVEN操作機理的問題分析論文

          匯編語言指令是機器指令的一種符號表示,不同類型的CPU就有不同的機器指令系統,也就有不同的匯編語言。除了同系列、不同型號CPU之間的匯編語言程序有一定程度的可移植性之外,其他不同類型CPU之間的匯編語言程序是無法移植的。

          正因為匯編語言具有“與機器相關性”的特性,程序員使用匯編語言編寫程序時,可以對機器內部的各種資源進行合理的安排,編寫出高效且需要對機器硬件精確控制的程序。所以掌握計算機系統的硬件結構對學習匯編語言具有很大幫助。

          在學習《匯編語言程序設計》課程時,有一條對準偽指令EVEN,其作用就是將下一個字節的地址設置為偶數,并且指出一個字的地址最好從偶地址開始。但其原因卻并沒有過多給以說明。因此,學生對它的功能比較茫然,為了充分說明該偽指令的功能,該文從8086微機系統的存儲器組織結構著手,詳細闡述這個問題。

          1 存儲器中的數據組織

          在計算機系統中,作為一個整體存入或取出內存儲器的數據稱為“存儲字”。例如:8位計算機的存儲字是8位字長(1個字節);16位計算機的存儲字是16位字長(2個字節)……

          對于內存儲器的字長(一個存儲單元所包含二進制代碼的個數),如果和主機的字長相同,則一個存儲單元存放一個存儲字,存儲字的地址就是存儲單元的地址,這種存儲器稱為“字編址結構”。但在微機系統中,內存儲器一般都是以字節作為基本存儲單元。這樣,對16位字長以及16位以上字長的計算機,一個存儲字將被存放在幾個連續的存儲單元中,這種存儲器稱為“字節編址結構”。

          2 8086微機系統的存儲器組織結構

          8086 CPU有16條數據線,20條地址線,可直接尋址1M字節的內存儲器地址空間,而這1M字節的存儲器地址空間是按字節順序排列的。由于8086是16位的微型計算機,而在16微機系統中,CPU除了可以對一個字節(8位)操作外,還可以進行一個字(16位)的操作。為了能滿足一次訪問一個整字又能訪問一個字節的要求,在8086微機系統中,1M字節的存儲器地址空間實際分成兩個512K字節的存儲體——“偶存儲體”和“奇存儲體”。兩個存儲體之間采用字節交叉編址方式。

          對于任何一個存儲體,只需要19條地址線(A19—A1)就可以直接尋址,剩下1條地址線(A0)用來區分當前訪問的是哪一個存儲體,A0=0時,表示訪問的是偶存儲體;A0=1時,表示訪問的是奇存儲體。

          在8086微機系統中,讀寫一個字節的信息時,可以直接采用上述方法進行操作,但讀寫一個整字的信息時,則需要同時訪問兩個存儲體,在這種情況下,若只用A0的取值來控制讀寫操作顯然就不行了。為此,在8086微機系統中,又增加一個總線高位有效控制信號。當有效時(低電平有效),選定奇存儲體,體內地址由A19—A1確定;當A0=0時,選定偶存儲體,體內地址同樣由A19—A1確定。奇存儲體和數據總線高8位(D15—D8)連接,偶存儲體和數據總線低8位(D7—D0)連接。有時候,奇存儲體稱為高字節存儲體,偶存儲體稱為低字節存儲體。因此,在8086微機系統中,允許CPU訪問任何一個存儲體,讀寫一個字節的信息或同時訪問兩個存儲體讀寫一個整字的信息。

          3 8086微機系統的存儲器讀/寫操作

          8086CPU訪問存儲器時,在一個總線周期內,既可以訪問一個字節,也可以訪問一個整字。

         。1)字節訪問。

          當8086CPU訪問一個字節信息時,可以分為兩種情況:

         、偃绻L問的字節是偶地址,則數據總線低8位(D7—D0)和偶存儲體之間直接進行數據傳送。

          ②如果訪問的字節是奇地址,則數據總線高8位(D15—D8)和奇存儲體之間直接進行數據傳送。

          由上可以看出,無論哪種情況,在一個總線周期內,都可以完成訪問一個字節的操作。

         。2)整字訪問。

          從上表可見,8086CPU能同時訪問奇存儲體和偶存儲體中的一個字節,以組成一個16位存儲字。此時,也有兩種情況:

         、偃绻L問的一個字的低8位字節存放在偶存儲體中,高8位字節存放在奇存儲體中,以這種方式存放的一個字稱為規則字。從上面分析可知,這時不需要字節交換地址交叉,直接就可以進行數據傳送。因而,只需經過一個總線周期就可完成對一個規則字的訪問。

          ②如果要訪問的一個字的高8位字節存放在偶存儲體中,低8位字節存放在奇存儲體中,以這種方式存放的一個字稱為非規則字。從上面分析可知,這時需要字節交換,才可以進行數據傳送。因而,需要經過兩個總線周期才可完成對一個非規則字的訪問。

          對于以非規則字方式存放的一個字的操作過程是這樣的(以寫操作為例):在第一個總線周期內,送出奇地址(A0=1),同時發出=0信號,然后由8086 CPU把該字的低8位傳送到數據總線的高8位(注意:此時發生了字節交換),寫入存儲器的奇存儲體;然后,在第二個總線周期內,8086 CPU又發出一個由該奇地址加1的偶地址,此時A0=0,=1,8086 CPU把該字的高8位傳送到數據總線的低8位(注意:此時又發生了字節交換),寫入存儲器的偶存儲體。這樣,經過二次存儲器訪問,才能把一個非規則字寫入存儲器的奇地址字單元。

          4 結語

          通過上面的分析,我們說可以得到如下的結論,在8086微機系統中,對于按字的讀寫操作(比如字數組),應盡可能地使要操作的數據,以規則字的方式存放在存儲器中,這樣,可以在一個總線周期內,完成一個字的讀寫操作,否則的話就需要用二個總線周期,從而使指令的執行時間延長。因此,在編寫匯編語言源程序時,涉及到操作多字的時候,往往在存放多字的前面,插入一條偽指令EVEN,目的就是使字的地址從偶地址開始,既使該字成為規則字。

          對于16位微機系統中,一個字存入存儲器要占有相繼的兩個字節,存放時,低位字節存入低地址,高位字節存入高地址,這樣兩個字節單元就構成了一個字單元,字單元的地址采用它的低地址來表示。

          例如:1:MOV AX,

          2;MOV AX,

          從上面的分析可知,第一條指令中的操作數是以規則字的                形式存放的,用一個總線周期的時間,就可以把操作數從存儲器中取出。第二條指令中的操作數是以非規則字的形式存放的,要用二個總線周期的時間,才可以把操作數從存儲器中取出。因此,執行第一條指令所需的時間要比執行第二條指令所需的時間少。

          32位微機系統中存儲器接口是16位的擴展,數據總線有32位,故有4個存儲體,每個存儲體占1GB存儲空間,存儲體選擇線通過字節允許線BE#0—BE#3實現,每個存儲體要有獨立的寫通信號。操作機理與8086微機系統基本一致。

          參考文獻

          沈美明.80X86匯編語言程序設計. 北京:清華大學出版社,2000.

          周明德.微型計算機系統原理及應用.北京:清華大學出版社,2005.

        【偽指令EVEN操作機理的問題分析論文】相關文章:

        匯編偽指令EVEN操作機理的問題分析論文02-25

        教育失敗問題分析論文03-04

        酒店管理服務問題分析論文03-02

        體育教學動力問題分析論文02-27

        邏輯哲學的核心問題分析論文02-14

        電子電路干擾問題分析論文03-09

        通信網絡優化問題分析論文01-01

        國企薪酬管理問題及對策分析論文02-26

        電能計量資產管理問題分析論文03-02

        企業激勵管理存在問題分析論文12-11

        国产高潮无套免费视频_久久九九兔免费精品6_99精品热6080YY久久_国产91久久久久久无码

        1. <tt id="5hhch"><source id="5hhch"></source></tt>
          1. <xmp id="5hhch"></xmp>

        2. <xmp id="5hhch"><rt id="5hhch"></rt></xmp>

          <rp id="5hhch"></rp>
              <dfn id="5hhch"></dfn>