什么是匯編語言
匯編語言(assembly language)是一種用于電子計算機、微處理器、微控制器或其他可編程器件的低級語言,亦稱為符號語言。在匯編語言中,用助記符(Mnemonics)代替機器指令的操作碼,用地址符號(Symbol)或標號(Label)代替指令或操作數的地址。在不同的設備中,匯編語言對應著不同的機器語言指令集,通過匯編過程轉換成機器指令。普遍地說,特定的匯編語言和特定的機器語言指令集是一一對應的,不同平臺之間不可直接移植。
許多匯編程序為程序開發、匯編控制、輔助調試提供了額外的支持機制。有的匯編語言編程工具經常會提供宏,它們也被稱為宏匯編器。
匯編語言不像其他大多數的程序設計語言一樣被廣泛用于程序設計。在今天的實際應用中,它通常被應用在底層,硬件操作和高要求的程序優化的場合。驅動程序、嵌入式操作系統和實時運行程序都需要匯編語言。
數據傳輸指令
一、通用數據傳送指令
1、傳送指令MOV (move)
指令的匯編格式:MOV DST,SRC
指令的基本功能:(DST)《-(SRC) 將原操作數(字節或字)傳送到目的地址。
指令支持的尋址方式:目的操作數和源操作數不能同時用存儲器尋址方式,這個限制適用于所有指令。
指令的執行對標志位的影響:不影響標志位。指令的特殊要求:
目的操作數DST和源操作數SRC不允許同時為段寄存器;目的操作數DST不能是CS,也不能用立即數方式。
2、進棧指令PUSH (push onto the stack)
出棧指令 POP (pop from the stack)
指令的匯編格式:PUSH SRC ;POP DST
指令的基本功能:PUSH指令在程序中常用來暫存某些數據,而POP指令又可將這些數據恢復。
PUSH SRC (SP)《-(SP)-2 ;(SP)《-(SRC)
POP DST (DST)《-((SP));(SP)《-(SP)
指令支持的尋址方式:push 和 pop指令不能不能使用立即數尋址方式。
指令對標志位的影響:PUSH 和 POP指令都不影響標志位。
指令的特殊要求:PUSH 和 POP指令只能是字操作,因此,存取字數據后,SP的修改必須是+2 或者 -2; POP指令的DST不允許是CS寄存器;
3、交換指令XCHG (exchange)
指令的匯編格式:XCHG OPR1,OPR2
指令的基本功能:(OPR1)《-》(OPR2)
指令支持的尋址方式:一個操作數必須在寄存器中,另一個操作數可以在寄存器或存儲器中。
指令對標志位的影戲:不影響標志位。
指令的特殊要求:不允許使用段寄存器。
二、累加器專用傳送指令
4、輸入指令IN (input)
輸出指令 OUT (output)
指令的匯編格式:IN ac,port port《=0FFH
IN ac,DX port》0FFH
OUT port,ac port《=0FFH
OUT DX,ac port》0FFH
指令的基本功能:對8086及其后繼機型的微處理機,所有I/O端口與CPU之間的通信都由輸入輸出指令IN和OUT來完成。IN指令將信息從I/O輸入到CPU,OUT指令將信息從CPU輸出到I/O端口,因此,IN和OUT指令都要指出I/O端口地址。
IN ac,port port《=0FFH (AL)《-(port)傳送字節或 (AX)《-(port+1,port)傳送字
IN ac,DX port》0FFH (AL)《-((DX))傳送字節或 (AX)《-((DX)+1,(DX))傳送字
OUT port,ac port《=0FFH (port)《-(AL)傳送字節或 (port+1,port)《-(AX)傳送字
OUT DX,ac port》0FFH (DX)《-(AL)傳送字節或 ((DX)+1,(DX))《-(AX)傳送字指令對標志位的影響:不影響標志位。
指令的特殊要求:只限于在AL或AX與I/O端口之間傳送信息。傳送16位信息用AX,傳送8位信息用AL,這取決于外設端口的寬度。
5、換碼指令XLAT (translate)
指令的匯編格式:XLAT opr 或 XLAT
指令的基本功能:這條指令根據AL寄存器提供的位移量,將BX指使的字節表格中的代碼換存在
AL中。 (AL)《-((DS)*16+(BX)+(AL))
指令對標志位的影響:不影響標志位。
指令的特殊要求:所建字節表格的長度不能超過256字節,因為存放位移量的是8位寄存器AL。opr為表格的首地址,因為opr所表示的偏移地址已存入BX寄存器,所以opr在換碼指令中可有可無,有則提高程序的可讀性。
三、地址傳送指令
6、有效地址傳送器LEA (load effective address)
指令的匯編格式:LEA reg,src
指令的基本功能:LEA指令把源操作數的有效地址送到指定的寄存器,這個有效地址是由src選定的一種存儲器尋址方式確定的。
指令支持的尋址方式:各種存儲器尋址方式。
指令對標志位的影響:不影響標志位。
指令的特出要求:指令中reg不能是段寄存器;
7、指針送寄存器和DS LDS (load DS with point)
指針送寄存器和ES LES (load ES with point)
指令的匯編格式:LDS reg,src LES reg,src
指令的基本功能:LDS和LES指令把確定內存單元位置的偏移地址送寄存器,段地址DS或ES。這個偏移地址和段地址(也稱地址指針)是由src指定的兩個相繼字單元提供的。
LDS reg,src (reg)《-(src) (DS)《-(src+2)
LES reg,src (reg)《-(src) (ES)《-(src+2)
指令支持的尋址方式:src必須為存儲器尋址方式
指令對標志位的影響:不影響標志位。
指令的特殊要求:指令中REG不能是段寄存器;
四、標志寄存器傳送指令
8、標志寄存器的低字節送AH LAHF (load AH with FLAGS)
指令的匯編格式:LAHF
指令的基本功能:(AH)《-(FLAGS)0-7
指令對標志位的影響:不影響標志位
9、AH送標志寄存器低字節 SAHF(store AH into FLAGS)
指令的格式:SAHF
指令的基本功能:(FLAGS)0-7《-(AH)
指令對標志位的影響:由裝入值來確定標志位的值。
10、標志進棧 PUSHF (push the flags)
指令的匯編格式:PUSHF
指令的基本功能:(SP)《-(SP)-2 ((SP)+1,(SP))《-(FLAGS)0-15
指令對標志位的影響:不影響標志位。
11、標志出棧 POPF (pop the FLAGES)
指令的匯編格式:POPF
指令的基本功能:(FLAGS)0-15《-((SP)+1,(SP)) (SP)《-(SP)+2
指令對標志位的影響:由裝入值來確定標志位的值。
算術指令
一、加法指令
12、加法指令ADD (addition)
指令的匯編格式:add dst,src
指令的基本功能:(dst)《-(src)+(dst)
指令支持的尋址方式:他們兩個操作數不能同時為存儲器尋址。即為除源操作數為立即數的情況外,源操作數和目地操作數必須有一個寄存器尋址方式。
指令對標志位的影響:SF=1 加法結果為負數(符號位為1)
SF=0 加法結果為正數(符號位為0)
ZF=1 加法結果為零
ZF=0 加法結果不為零
CF=1 最高有效位向高位有進位
CF=0 最高有效位向高位無進位
OF=1 兩個同符號數相加(正數+正數或負數+負數),結果符號與其相反。
OF=0 兩個不同符號數相加,或同符號數相加,結果符號與其相同。
13、帶進為加法指令ADC (add with carry)
指令的匯編格式:ADD dst,src
指令的基本功能:(dst)《-(src)+(dst)+CF
指令支持的尋址方式:他們兩個操作數不能同時為存儲器尋址。即為除源操作數為立即數的情況外,源操作數和目地操作數必須有一個寄存器尋址方式。
指令對標志位的影響:SF=1 加法結果為負數
SF=0 加法結果為正數
ZF=1 加法結果為零
ZF=0 加法結果不為零
CF=1 最高有效位向高位有進位
CF=0 最低有效位相高位無進位
OF=1 兩個同符號數相加,結果符號與其相反,
OF=0 兩個同符號數相加,或同符號相加,結果符號與其相同
14、加1指令INC (increament)
指令的匯編格式:INC opr
指令的基本功能:(opr)《-(opr)
指令支持的尋址方式可以使用除立即數方式外的任何尋址方式
指令對標志位的影響:SF=1 加法結果為負數
SF=0 加法結果為正數
ZF=1 加法結果為零
ZF=0 加法結果不為零
OF=1 兩個同符號數相加,結果符號與其相反,
OF=0 兩個同符號數相加,或同符號相加,結果符號與其相同。
二、減法指令
15、減法指令SUB (subtract)
指令的匯編格式:SUB dst,src
指令的基本功能:(dst)《-(dst)-(src)
指令支持的尋址方式:他們兩個操作數不能同時為存儲器尋址。即為除源操作數為立即數的情況外,源操作數和目地操作數必須有一個寄存器尋址方式。
指令對標志位的影響:SF=1 減法結果為負數(符號位為1)
SF=0 減法結果為正數(符號位為0)
ZF=1 減法結果為零
ZF=0 減法結果不為零
CF=1 二進制減法運算中最高有效位向高位有借位(被減數小于減數,不夠減的情況)
CF=0 二進制減法運算中最高有效為向高位無借位(被減數〉=減數,夠減的情況)
OF=1 兩數符號相反(正數-負數,或負數-正數),而結果符號與減數相同。
OF=0 同符號數相減時,或不同符號數相減,其結果符號與減數不同。
16、帶借位減法指令SBB (subtract with borrow)
指令的匯編格式:SBB dst,src
指令的基本功能:(dst)《-(dst)-(src)-CF
指令支持的尋址方式:他們兩個操作數不能同時為存儲器尋址。即為除源操作數為立即數的情況外,源操作數和目地操作數必須有一個寄存器尋址方式。
指令對標志位的影響:SF=1 減法結果為負數(符號位為1)
SF=0 減法結果為正數(符號位為0)
ZF=1 減法結果為零
ZF=0 減法結果不為零
CF=1 二進制減法運算中最高有效位向高位有借位(被減數小于減數,不夠減的情況)
CF=0 二進制減法運算中最高有效為向高位無借位(被減數〉=減數,夠減的情況)
OF=1 兩數符號相反(正數-負數,或負數-正數),而結果符號與減數相同。
OF=0 同符號數相減時,或不同符號數相減,其結果符號與減數不同。
17、減1指令DEC (decrement)
指令的匯編格式:DEC opr
指令的基本功能:(opr)《-(opr)-1
指令支持的尋址方式:可以使用除立即數方式外的任何尋址方式。
指令對標志位的影響:SF=1 減法結果為負數(符號位為1)
SF=0 減法結果為正數(符號位為0)
ZF=1 減法結果為零
ZF=0 減法結果不為零
OF=1 兩數符號相反(正數-負數,或負數-正數),而結果符號與減數相同。
OF=0 同符號數相減時,或不同符號數相減,其結果符號與減數不同。
18、比較指令CMP (compare)
指令的匯編格式:CMP opr1,opr2
指令的基本功能:(opr1)-(opr2),根據相減結果設置條件碼,但不回送結果。
指令支持的尋址方式:他們兩個操作數不能同時為存儲器尋址。即為除源操作數為立即數的情況外,源操作數和目地操作數必須有一個寄存器尋址方式。
指令對標志位的影響:
SF=1 減法結果為負數(符號位為1)
SF=0 減法結果為正數(符號位為0)
ZF=1 減法結果為零
ZF=0 減法結果不為零
CF=1 二進制減法運算中最高有效位向高位有借位(被減數小于減數,不夠減的情況)
CF=0 二進制減法運算中最高有效為向高位無借位(被減數〉=減數,夠減的情況)
OF=1 兩數符號相反(正數-負數,或負數-正數),而結果符號與減數相同。
OF=0 同符號數相減時,或不同符號數相減,其結果符號與減數不同。
19、求補指令NEG (negate)
指令的匯編格式:NEG opr
指令的基本功能:(opr)《- -(opr)
指令支持的尋址方式:可以使用除立即數方式外的任何尋址方式。
指令對標志位的影響:CF=1 不為0的操作數求補時
CF=0 為0的操作數求補時
OF=1 操作數為-128(字節運算)或操作數為-32768(字運算)
OF=0 當求補運算的操作數不為-128(字節)或-32768(字)時三、乘法指令
20、無符號乘法指令NUL (unsigned multiple)
有符號乘法指令 IMUL(signed muliple)
指令的匯編格式:NUL src IMUL src
指令的基本功能:(AX)《-(AL)*(src) (DX,AX)《-(AX)*(src)
指令支持的尋址方式:src可以使用除立即數方式以外的任一種尋址方式。
指令對標志位的影響:乘法指令只影響標志位CF和OF,其他條件碼位無定義。MUL指令的條件碼設置為:
CF OF=0 0 乘積的高一半為0(字節操作的(AH)或字操作的(DX))
CF OF=1 1 乘積的高一半不為0
IMUL指令的條件碼設置為:
CF OF=0 0 乘積的高一半為低一半的符號擴展。
CF OF=1 1 其他情況
指令的特殊要求:MUL和IMUL指令的區別僅在于操作數是無符號還是帶符號數,它們的共同點是,指令中只給出源操作數src,目的操作數是隱含的,它只能是累加器(字運算為AX,字節運算為AL)。隱含的乘積寄存器是AX或DX(高位)和AX(低位)。
四、符號擴展指令
21、節擴展為字CBW (convert byte to word)
指令的匯編格式:CBW
指令的基本功能:(AH)=00H 當(AL)的最高有效位為0時
(AH)=FFH 當(AL)的最高有效位為1時
指令對標志位的影響:不影響標志位
指令的特殊要求:這是條無操作數的指令,進行符號擴展的操作數必須存放在AL寄存器 AX寄存器中。
22、字擴展為雙字CWD (convert word to double word)
指令的匯編格式:CWD
指令的基本功能:(DX)=0000H 當(AX)的最高有效位為0時
(DX)=FFFFH 當(AX)的最高有效位為1時
指令對標志位的影響:不影響標志位
指令的特殊要求:這是條無操作數的指令,進行符號擴展的操作數必須存放在AL寄存器或AX寄存器中。
五、除法指令23、無符號數除法DIV (unsigned divide)
帶符號數除法 IDIV (singed divide)
指令的匯編格式:DIV src IDIV src
指令的基本功能:字操作
(AL)《-(AX)/src的商 (AH)《-(AX)/src的余數字節操作
(AX)《-(DX,AX)/src的商 (DX)《-(DX,AX)/src的余數
指令支持的尋址方式:src作為除數,可用除立即數以外的任一種尋址方式來取得。
指令對標志位的影響:不影響條件碼。
指令的特殊要求:除法指令要求字操作時,被除數必須為32位,除數是16位,商和余數是16位的;字節操作時,被除數必須為16位,除數是8位,得到的商和余數是8位的。
六、十進制調整指令
邏輯指令
一、邏輯運算指令的格式:AND dst,src
指令的基本功能:(dst)《-(dst)與(src)
指令支持的尋址方式:兩個操作數不能同時為存儲器尋址。即為除源操作數為立即數的情況外,源操作數和目地操作數必須有一個寄存器尋址方式。
指令對標志位的影響:指令執行后CF 和OF 置零,AF無定義。
SF=1 指令執行后的結果為負數(符號位為1)
SF=0 指令執行后的結果為正數(符號位為0)
ZF=1 指令執行后的結果為零
ZF=0 指令執行后的結果不為零
PF=1 結果操作數中1的個數為偶數時置1
PF=0 結果操作數中1的個數為奇數時置0
25、邏輯或OR (logic or)
指令的匯編格式:OR dst,src
指令的基本功能:(dst)《-(dst)或(src)
指令支持的尋址方式:兩個操作數不能同時為存儲器尋址。即為除源操作數為立即數的情況外,原操作數和目的操作數必須有一個寄存器尋址方式。
指令對標志位的影響:令執行后CF 和OF 置零,AF無定義。
SF=1 指令執行后的結果為負數(符號位為1)
SF=0 指令執行后的結果為正數(符號位為0)
ZF=1 指令執行后的結果為零
ZF=0 指令執行后的結果不為零
PF=1 結果操作數中1的個數為偶數時置1
PF=0 結果操作數中1的個數為奇數時置0
26、邏輯非NOT (logic not)
指令的匯編格式:NOT orc
指令的基本功能:(dst)《-(opr)
指令支持的尋址方式:除立即數尋址方式以外的其余尋址方式
指令對標志位的影響:對標志位無影響
27、異或XOR (exclusice or)
指令的匯編格式:XOR dst,src
指令的基本功能:(dst)《-(dst)異或(src)
指令支持的尋址方式:兩個操作數不能同時為存儲器尋址。即為除源操作數為立即數的情況外,原操作數和目的操作數必須有一個寄存器尋址方式。
指令對標志位的影響:令執行后CF 和OF 置零,AF無定義。
SF=1 指令執行后的結果為負數(符號位為1)
SF=0 指令執行后的結果為正數(符號位為0)
ZF=1 指令執行后的結果為零
ZF=0 指令執行后的結果不為零
PF=1 結果操作數中1的個數為偶數時置1
PF=0 結果操作數中1的個數為奇數時置0
28、測試指令TEST
指令的匯編格式:TEST opr1,opr2
指令的基本功能:(opr1)與(opr2)
指令支持的尋址方式:兩個操作數不能同時為存儲器尋址,即為除源操作數為立即數的情況外,源操作數和目的操作數必須有一個寄存器尋址方式。
指令對標志位的影響:令執行后CF 和OF 置零,AF無定義。
SF=1 指令執行后的結果為負數(符號位為1)
SF=0 指令執行后的結果為正數(符號位為0)
ZF=1 指令執行后的結果為零
ZF=0 指令執行后的結果不為零
PF=1 結果操作數中1的個數為偶數時置1
PF=0 結果操作數中1的個數為奇數時置0
二、移位指令
29、邏輯左移SHL (shift logical left)
指令的匯編格式:SHL dst,cnt
指令的基本功能:SHL指令向左逐位移動cnt次,每次逐位移動后,最低位用0來補充,最高位移入CF。
指令支持的尋址方式:目的操作數dst可以是除立即數外的任何尋址方式。移位次數(或位數)cnt=1時,1可以直接寫在指令中,cnt〉1時,cnt必須放入CL寄存器中。
指令對標志位的影響:CF=移入的數值
OF=1 當cnt=1時,移動后最高位的值發生變化。
OF=0 當cnt=1時,移動時最高位的值未發生變化。
SF、ZF、PF根據移動后的結果設置
30、邏輯右移SHR (shift logical right)
指令的匯編格式:SHR dst,cnt
指令的基本功能:SHR指令向右逐位移動cnt次,每次逐位移動后,最高位用0來補充,最低位移入CF。
指令支持的尋址方式:目的操作數dst可以是除立即數外的任何尋址方式。移位次數(或位數)cnt=1時,1可以直接寫在指令中,cnt〉1時,cnt必須放入CL寄存器中。
指令對標志位的影響:CF=移入的數值
OF=1 當cnt=1時,移動后最高位的值發生變化。
OF=0 當cnt=1時,移動時最高位的值未發生變化。
SF、ZF、PF根據移動后的結果設置。
31、算術左移SAL (shift arithmetic left)
指令的匯編格式:SAL dst cnt
指令的基本功能:SAL指令向左逐位移動cnt次,每次逐位移動后,最低位用0來補充,最高位移入CF。
指令支持的尋址方式:目的操作數dst可以是除立即數外的任何尋址方式。移位次數(或位數)cnt=1時,1可以直接寫在指令中,cnt〉1時,cnt必須放入CL寄存器中。
指令對標志位的影響:CF=移入的數值
OF=1 當cnt=1時,移動后最高位的值發生變化。
OF=0 當cnt=1時,移動時最高位的值未發生變化。
SF、ZF、PF根據移動后的結果設置。
32、算術右移SAR (shift arithmetic right)
指令的匯編格式:SAR dst,cnt
指令的基本功能:SAR指令向右逐位移動cnt次,每次逐位移動后,最高位用符號位來補充,最低位移入CF。
指令支持的尋址方式:目的操作數dst可以是除立即數外的任何尋址方式。移位次數(或位數)cnt=1時,1可以直接寫在指令中,cnt〉1時,cnt必須放入CL寄存器中。
指令對標志位的影響:CF=移入的數值
OF=1 當cnt=1時,移動后最高位的值發生變化。
OF=0 當cnt=1時,移動時最高位的值未發生變化。
SF、ZF、PF根據移動后的結果設置。
33、循環左移ROL (rotate left)
指令的匯編格式:ROL dst,cnt
指令的基本功能:ROL 對由dst指定的寄存器或存儲器操作數左移循環移動cnt所指定的次數,每左移一次,把最高位同時移入CF和操作數最低位。指令支持的尋址方式:目的操作數dst可以是除立即數外的任何尋址方式。移動次數(或位數)cnt=1時,1可以直接寫在指令中,cnt〉1時,cnt必須放入CL寄存器中。
指令對標志位的影響:CF=移入的數值
OF=1 當cnt=1時,移動后最高位的值發生變化。
OF=0 當cnt=1時,移動時最高位的值未發生變化。
SF、ZF、PF根據移動后的結果設置。
34、循環右移ROR (rotate right)
指令的匯編格式:ROR dst,cnt
指令的基本功能:ROR 對由dst指定的寄存器或存儲器操作數右移循環移動cnt所指定的次數,每右移一次,把最低位同時移入CF和操作數最高位。
指令支持的尋址方式:目的操作數dst可以是除立即數外的任何尋址方式。移動次數(或位數)cnt=1時,1可以直接寫在指令中,cnt》1時,cnt必須放入CL寄存器中。
評論
查看更多