代碼段在什麼存儲器
① 什麼是代碼段什麼是數據段它們在匯編中完成什麼內容
代碼段就是放代碼的地方,數據段就是放數據的地方
當然這只是個模糊的標准,在8086下是可以在代碼段放數據的,但在windows保護模式下就不行了,如果在代碼區定義數據的話,這個數據在默認情況下是不可讀和不可寫的
在8086下,所謂段對應的是段寄存器,每個段在某一時刻都可能有一個段寄存器與之對應,比如CS對應代碼段,DS對應數據段
② 8086/8088系統中,存儲器為什麼要分段,一個段的最大和最小各為多少位元組
8086/8088系統中,存儲器分段的主要目的是便於存儲器的管理,使得可以用16位寄存器來定址20位的內存空間。一個段最大為64KB,最小為16B。
存儲器一般用來保存程序的中間結果,為隨後的指令快速提供操作數,從而避免把中間結果存入內存,再讀取內存的操作。
由於存儲器的個數和容量都有限,不可能把所有中間結果都存儲在存儲器中,所以,要對存儲器進行適當的調度。根據指令的要求,管理安排適當的寄存器,避免操作數過多的傳送操作。
8086/8088CPU可直接定址1MB的存儲器空間,直接定址需要20位地址碼,而所有內部寄存器都是16位的,只能直接定址6KB,因此採用分段技術來解決。將1MB的存儲空間分成若干邏輯段,每段最長64KB,最短16B。這些邏輯段在整個存儲空間中可浮動。
(2)代碼段在什麼存儲器擴展閱讀:
8086/8088CPU內部設置了4個16位段寄存器,它們分別是代碼段寄存器CS、數據段寄存器DS、堆棧段寄存器SS、附加段寄存器ES、由它們給出相應邏輯段的首地址,稱為「段基址」。段基址與段內偏移地址組合形成20位物理地址,段內偏移地址可以存放在寄存器中,也可以存放在存儲器中。
程序較小時,代碼段、數據段、堆棧段可放在一個段內,即包含在64KB之內,而當程序或數據量較大時,超過了64KB,那麼可以定義多個代碼段或數據段、堆棧段、附加段。
③ 匯編語言寄存器都叫什麼
1、寄存器
32位寄存器有16個,分別是:
4個數據寄存器(EAX、EBX、ECX、EDX)。
2個變址和指針寄存器(ESI和EDI);2個指針寄存器(ESP和EBP)。
6個段寄存器(ES、CS、SS、DS、FS、GS)。
1個指令指針寄存器(EIP);1個標志寄存器(EFlags)。
2、數據寄存器
數據寄存器主要用來保存操作數和運算結果等信息,從而節省讀取操作數所需佔用匯流排和訪問存儲器的時間。
32位CPU有4個32位通用寄存器:EAX、EBX、ECX和EDX。對低16位數據的取存,不會影響高16
位的數據,這些低16位寄存器分別命名為AX、BX、CX和DX,它和先前的CPU中的寄存器相一致。
4個16位寄存器又可分割成8個獨立的8位寄存器(AX:ah~al、BX:bh~bl、CX:ch~cl:DX:dh~dl)。
每個寄存器都有自己的名稱,可獨立存取。程序員可利用數據寄存器的這種「可合可分」的特性,靈活地處理字/
位元組的信息。
AX和al通常稱為累加器,用累加器進行的操作可能需要更少時間,累加器可用於乘、除、輸入/輸出等操作,
它們的使用頻率很高。
BX稱為基地址寄存器,它可作為存儲器指針來使用。
CX稱為計數寄存器,在循環和字元串操作時,要用它來控制循環次數;在位操作中,當移多位時,要用cl來
指明位移的位數。
DX稱為數據寄存器,在進行乘、除運算時,它可以為默認的操作數參與運算,也可用於存放I/O的埠地址。
在16位CPU中,AX、BX、CX和DX不能作為基址和變址寄存器來存放存儲單元的地址,但在32位CPU
中,其32位寄存器EAX、EBX、ECX和EDX不僅可傳送數據、暫存數據、保存算術邏輯運算結果,而且也可
作為指針寄存器,所以,這些32位寄存器更具有通用性。
3、變址寄存器
32位CPU有2個32位通用寄存器ESI和EDI,其低16位對應先前CPU中的SI和DI,對低16位數據的
存取,不影響高16位的數據。
ESI、EDI、SI和DI稱為變址寄存器,它們主要用於存放存儲單元在段內的偏移量,用它們可實現多種存儲器
操作數的定址方式,為以不同的地址形式訪問存儲單元提供方便。
變址寄存器不可分割成8位寄存器,作為通用寄存器,也可存儲算術邏輯運算的操作數和運算結果。
它們可作一般的存儲器指針使用,在字元串操作指令的執行過程中,對它們有特定的要求,而且還具有特殊的
功能。
4、指針寄存器
32位CPU有2個32位通用寄存器EBP和ESP,其低16位對應先前CPU中的BP和SP,對低16位數
據的存取,不影響高16位的數據。
EBP、ESP、BP和SP稱為指針寄存器,主要用於存放堆棧內存儲單元的偏移量,用它們可實現多種存儲器
操作數的定址方式,為以不同的地址形式訪問存儲單元提供方便。
指針寄存器不可分割成8位寄存器,作為通用寄存器,也可存儲算術邏輯運算的操作數和運算結果。
它們主要用於訪問堆棧內的存儲單元,並且規定:
BP為基指針寄存器,用它可直接存取堆棧中的數據。
SP為堆棧指針寄存器,用它只可訪問棧頂。
5、段寄存器
段寄存器是根據內存分段的管理模式而設置的。內存單元的物理地址由段寄存器的值和一個偏移量組合而成
的,這樣可用兩個較少位數的值組合成一個可訪問較大物理空間的內存地址。
32位CPU有6個段寄存器,分別如下:
CS:代碼段寄存器 ES:附加段寄存器
DS:數據段寄存器 FS:附加段寄存器
SS:堆棧段寄存器 GS:附件段寄存器
在16位CPU系統中,只有4個段寄存器,所以,程序在任何時刻至多有4個正在使用的段可直接訪問,在
32位微機系統中,它有6個段寄存器,所以在此環境下開發的程序最多可同時訪問6個段。
32位CPU有兩個不同的工作方式:實方式和保護方式。在每種方式下,段寄存器的作用是不同的,有關規定
簡單描述如下:
實方式:段寄存器CS、DS、ES和SS與先前CPU中的所對應的段寄存器的含義完全一致,內存單元的邏輯
地址仍為「段地址:偏移地址」的形式,為訪問某內存段內的數據,必須使用該段寄存器和存儲單元的偏移地址。
保護方式:在此方式下,情況要復雜得多,裝入段寄存器的不再是段值,而是稱為「選擇子」的某個值。
6、指令指針寄存器
32位CPU把指令指針擴展到32位,並記作EIP,EIP的低16位與先前CPU中的IP作用相同。
指令指針EIP、IP是存放下次將要執行的指令在代碼段的偏移地址,在具有預取指令功能的系統中,下次要執
行的指令通常已被預取到指令隊列中,除非發生轉移情況,所以,在理解它們的功能時不考慮存在指令隊列的情
況。
在實方式下,由於每個段的最大范圍為64KB,所以,EIP的高16位肯定都為0,此時,相當於只用其低16
位的IP來反映程序中的指令的執行次序。
7、標志寄存器
1.運算結果標志位。一共6個,包括:CF進位標志位、PF奇偶標志位、AF輔助進位標志位、ZF零標志位、
SF符號標志位、OF溢出標志位。
2.狀態控制標志位。一共3個,包括:TF追蹤標志位、IF中斷允許標志位、DF方向標志位。
以上標志位在第7章里都講過了,在這里就不再解釋了,現在講講32位標志寄存器增加的4個標志位。
1. I/O特權標志IOPL。
IOPL用兩位二進制位來表示,也稱為I/O特權級欄位,該欄位指定了要求執行I/O指令的特權級,如果當前
的特權級別在數值上小於等於IOPL的值,那麼,該I/O指令可執行,否則將發生一個保護異常。
2. 嵌套任務標志NT。
NT用來控制中斷返回指令IRET的執行。具體規定如下:
(1) 當NT=0,用堆棧中保存的值恢復EFlags、CS和EIP,執行常規的中斷返回操作。
(2) 當NT=1,通過任務轉換實現中斷返回。
3. 重啟動標志RF。
RF用來控制是否接受調試故障。規定:RF=0時,表示接受,否則拒絕。
4. 虛擬8086方式標志VM。
如果VM=1,表示處理機處於虛擬的8086方式下的工作狀態,否則,處理機處於一般保護方式下的工作狀態。
8、32位地址的定址方式
最後說一下32位地址的定址方式。在前面我們學習了16位地址的定址方式,一共有5種,在32位微機系統
中,又提供了一種更靈活、方便但也更復雜的內存定址方式,從而使內存地址的定址范圍得到了進一步擴大。
在用16位寄存器來訪問存儲單元時,只能使用基地址寄存器(BX和BP)和變址寄存器(SI和DI)來作為
偏移地址的一部分,但在用32位寄存器定址時,不存在上述限制,所有32位寄存器(EAX、EBX、ECX、
EDX、ESI、EDI、EBP、和ESP)都可以是偏移地址的一個組成部分。
當用32位地址偏移量進行定址時,偏移地址可分為3部分:
1. 一個32位基址寄存器(EAX、EBX、ECX、EDX、ESI、EDI、EBP、ESP)。
2. 一個可乘以1、2、4、8的32位變址寄存器(EAX、EBX、ECX、EDX、ESI、EDI和EBP)。
3. 一個8位~32位的偏移常量。
比如,指令:mov ebx, [eax+edx*2+300]
Eax就是基址寄存器,edx就是變址寄存器,300H就是偏移常量。
上面那3部分可進行任意組合,省去其中之一或之二。
下面列舉幾個32位地址定址指令:
Mov ax, [123456]
Mov eax, [ebx]
Mov ebx, [ecx*2]
Mov ebx, [eax+100]
Mov ebx, [eax*4+200]
Mov ebx, [eax+edx*2]
Mov ebx, [eax+edx*4+300]
Mov ax, [esp]
由於32位定址方式能使用所有的通用寄存器,所以,和該有效地址相組合的段寄存器也就有新的規定,具體
規定如下:
1. 地址中寄存器的書寫順序決定該寄存器是基址寄存器還是變址寄存器。
如:[ebx+ebp]中的ebx是基址寄存器,ebp是變址寄存器,而[ebp+ebx]中的ebp是基址寄存器,ebx是變
址寄存器,可以看出,左邊那個是基址寄存器,另一個是變址寄存器。
2. 默認段寄存器的選用取決於基址寄存器。
3. 基址寄存器是ebp或esp時,默認的段寄存器是SS,否則,默認的段寄存器是DS。
4. 在指令中,如果顯式地給出段寄存器,那麼顯式段寄存器優先。
下面列舉幾個32位地址定址指令及其內存操作數的段寄存器。
指令列舉: 訪問內存單元所用的段寄存器
mov ax, [123456] ;默認段寄存器為DS。
mov ax, [ebx+ebp] ;默認段寄存器為DS。
mov ebx, [ebp+ebx] ;默認段寄存器為SS。
mov ebx, [eax+100] ;默認段寄存器為DS。
mov edx, ES:[eax*4+200] ;顯式段寄存器為ES。
mov [esp+edx*2], ax ;默認段寄存器為SS。
mov ebx, GS:[eax+edx*8+300] ;顯式段寄存器為GS。
mov ax, [esp] ;默認段寄存器為SS。
④ 機器指令是存放在哪個存儲器中
所有指令是協調工作的
我想這些指令也是存儲與不同的寄存器中。
並不是孤立的哪一個上面。
~~~~~~~~
寄存器是中央處理器內的其中組成部份。寄存器是有限存貯容量的高速存貯部件,它們可用來暫存指令、數據和位址。在中央處理器的控制部件中,包含的寄存器有指令寄存器(IR)和程序計數器(PC)。在中央處理器的算術及邏輯部件中,包含的寄存器有累加器(ACC)。
寄存器(Register)
寄存器是內存階層 中的最頂端,也是系統操作資料的最快速途徑。寄存器通常都是以他們可以保存的 位元 數量來估量,舉例來說,一個 "8 位元寄存器" 或 "32 位元 寄存器"。寄存器現在都以寄存器檔案 的方式來實作,但是他們也可能使用單獨的正反器、高速的核心內存、薄膜內存 以及在數種機器上的其他方式來實作出來。
寄存器通常都用來意指由一個指令之輸出或輸入可以直接索引到的暫存器群組。更適當的是稱他們為 "架構寄存器"。
例如,x86 指令及定義八個 32 位元寄存器的集合,但一個實作 x86 指令集的 CPU 可以包含比八個更多的寄存器。
寄存器是CPU內部的元件,寄存器擁有非常高的讀寫速度,所以在寄存器之間的數據傳送非常快。
寄存器的用途:
1.可將寄存器內的數據執行算術及邏輯運算。
2.存於寄存器內的地址可用來指向內存的某個位置,即定址。
3.可以用來讀寫數據到電腦的周邊設備。
8086 有8個8位數據寄存器,
這些8位寄存器可分別組成16位寄存器:
AH&AL=AX:累加寄存器,常用於運算;
BH&BL=BX:基址寄存器,常用於地址索引;
CH&CL=CX:計數寄存器,常用於計數;
DH&DL=DX:數據寄存器,常用於數據傳遞。
為了運用所有的內存空間,8086設定了四個段寄存器,專門用來保存段地址:
CS(Code Segment):代碼段寄存器;
DS(Data Segment):數據段寄存器;
SS(Stack Segment):堆棧段寄存器;
ES(Extra Segment):附加段寄存器。
當一個程序要執行時,就要決定程序代碼、數據和堆棧各要用到內存的哪些位置,通過設定段寄存器 CS,DS,SS 來指向這些起始位置。通常是將DS固定,而根據需要修改CS。所以,程序可以在可定址空間小於64K的情況下被寫成任意大小。 所以,程序和其數據組合起來的大小,限制在DS 所指的64K內,這就是COM文件不得大於64K的原因。8086以內存做為戰場,用寄存器做為軍事基地,以加速工作。
除了前面所提的寄存器外,還有一些特殊功能的寄存器:
IP(Intruction Pointer):指令指針寄存器,與CS配合使用,可跟蹤程序的執行過程;
SP(Stack Pointer):堆棧指針,與SS配合使用,可指向目前的堆棧位置。
BP(Base Pointer):基址指針寄存器,可用作SS的一個相對基址位置;
SI(Source Index):源變址寄存器可用來存放相對於DS段之源變址指針;
DI(Destination Index):目的變址寄存器,可用來存放相對於 ES 段之目的變址指針。
還有一個標志寄存器FR(Flag Register),有九個有意義的標志(
OF: 溢出標志位OF用於反映有符號數加減運算所得結果是否溢出。如果運算結果超過當前運算位數所能表示的范圍,則稱為溢出,OF的值被置為1,否則,OF的值被清為0.
DF: 方向標志DF位用來決定在串操作指令執行時有關指針寄存器發生調整的方向。
IF: 中斷允許標志IF位用來決定CPU是否響應CPU外部的可屏蔽中斷發出的中斷請求。但不管該標志為何值,CPU都必須響應CPU外部的不可屏蔽中斷所發出的中斷請求,以及CPU內部產生的中斷請求。具體規定如下:
(1)、當IF=1時,CPU可以響應CPU外部的可屏蔽中斷發出的中斷請求;
(2)、當IF=0時,CPU不響應CPU外部的可屏蔽中斷發出的中斷請求。
TF: 狀態控制標志位是用來控制CPU操作的,它們要通過專門的指令才能使之發生改變
SF: 符號標志SF用來反映運算結果的符號位,它與運算結果的最高位相同。在微機系統中,有符號數採用補碼表示法,所以,SF也就反映運算結果的正負號。運算結果為正數時,SF的值為0,否則其值為1。
ZF: 零標志ZF用來反映運算結果是否為0。如果運算結果為0,則其值為1,否則其值為0。在判斷運算結果是否為0時,可使用此標志位。
AF: 下列情況下,輔助進位標志AF的值被置為1,否則其值為0:
(1)、在字操作時,發生低位元組向高位元組進位或借位時;
(2)、在位元組操作時,發生低4位向高4位進位或借位時。
PF: 奇偶標志PF用於反映運算結果中「1」的個數的奇偶性。如果「1」的個數為偶數,則PF的值為1,否則其值為0。
CF: 進位標志CF主要用來反映運算是否產生進位或借位。如果運算結果的最高位產生了一個進位或借位,那麼,其值為1,否則其值為0。)
以上是8086寄存器的整體概況, 自80386開始,PC進入
32bit時代,其定址方式,寄存器大小, 功能等都發生了變化, 要想學習這方面知識請參考相應資料.
⑤ 單片機數據段屬於ram的一部分,代碼段屬於rom的一部分,這樣理解對嗎
可以這樣理解,單片機的數據存儲器和程序存儲器是分開的,計算產生的數據存放於RAM,而程序只能存放於ROM
⑥ 急急急!!!匯編語言裡面,代碼段裡面存儲的是什麼
代碼段裡面存儲的確實是指令
但是要告訴你的是,無論數據段,代碼段還是什麼段,用的都是同一個存儲空間,這個存儲空間由基址和偏移地址確定位置,每個位置存儲一個位元組,也就是2位16進制數。機器會給代碼段一個對應的首位置,然後你寫的代碼都會轉成2位16進制數存入其中。
比如說我有1到50的存儲空間,也就是50個位元組,你的數據段對應首址是5,那麼你在數據段中定義的數據會挨個存在5,6,7....中。如果你的代碼段對應首址是30,那麼你在代碼段中寫的一句指令「mov ax,bx」會轉成16進制碼(具體是什麼我就不知道了,我曾經試過,好像沒有十分准確的對應關系)存到30,31,32...的存儲空間中。
不知道這樣說你名不明白
⑦ 段寄存器是在CPU內部還是存儲器里如果是在cpu內,那麼cpu訪問存儲器時,存儲器地址由段寄存器,ip決定
你問的是8086架構的CPU吧,看的很眼熟,很多年都沒接觸了。8086中有4個16位的段寄存器:CS、DS、SS、ES,分別用於存放可執行代碼的代碼段、數據段、堆棧段和其他段的基地址。
其中,段寄存器CS指向存放程序的內存段,IP是用來存放下條待執行的指令在該段的偏移量,把它們合在一起可在該內存段內取到下次要執行的指令。
段寄存器SS指向用於堆棧的內存段,SP是用來指向該堆棧的棧頂,把它們合在一起可訪問棧頂單元。
段寄存器DS指向數據段,ES指向附加段,在存取操作數時,二者之一和一個偏移量合並就可得到存儲單元的物理地址。通常,預設的數據段寄存器是DS。
⑧ 存儲器的代碼段就是代碼段寄存器嗎存儲器不是說的內存嗎怎麼了內存又是代碼段寄存器了到底什麼是存
你需要看書而不是來提問,因為你最基礎的東東都在混沌狀態。你要搞清楚的是什麼是內存、什麼是寄存器。搞清楚了之後再討論代碼、數據段的問題,然後自然就明白代碼段寄存器,人為把內存劃為幾個段,而訪問這幾個段就要用相應寄存器!
⑨ 單片機應用程序一般存放在(ROM)里嗎若不是,那存在哪裡
是存在ROM里的,現在的單片機一般是FLASH型ROM