置頂 各種標誌位的含義

2021-08-04 18:05:39 字數 1660 閱讀 6693

一、運算結果標誌位進製標誌cf主要用來反映運算是否產生進製或借位。如果運算結果的最高位產生了乙個進製或借位,那麼,其值為1,否則其值為0。

使用該標誌位的情況有:多字(位元組)數的加減運算,無符號數的大小比較運算,移位操作,字(位元組)之間移位,專門改變cf值的指令等。

奇偶標誌pf用於反映運算結果中「1」的個數的奇偶性。如果「1」的個數為偶數,則pf的值為1,否則其值為0。

利用pf可進行奇偶校驗檢查,或產生奇偶校驗位。在資料傳送過程中,為了提供傳送的可靠性,如果採用奇偶校驗的方法,就可使用該標誌位。

在發生下列情況時,輔助進製標誌af的值被置為1,否則其值為0:

(1)、在字操作時,發生低位元組向高位元組進製或借位時;

(2)、在位元組操作時,發生低4位向高4位進製或借位時。

對以上6個運算結果標誌位,在一般程式設計情況下,標誌位cf、zf、sf和of的使用頻率較高,而標誌位pf和af的使用頻率較低。

零標誌zf用來反映運算結果是否為0。如果運算結果為0,則其值為1,否則其值為0。在判斷運算結果是否為0時,可使用此標誌位。

符號標誌sf用來反映運算結果的符號位,它與運算結果的最高位相同。在微機系統中,有符號數採用補碼表示法,所以,sf也就反映運算結果的正負號。運算結果為正數時,sf的值為0,否則其值為1。

溢位標誌of用於反映有符號數加減運算所得結果是否溢位。如果運算結果超過當前運算位數所能表示的範圍,則稱為溢位,of的值被置為1,否則,of的值被清為0。

「溢位」和「進製」是兩個不同含義的概念,不要混淆。如果不太清楚的話,請查閱《計算機組成原理》課程中的有關章節。

狀態控制標誌位是用來控制cpu操作的,它們要通過專門的指令才能使之發生改變。

當追蹤標誌tf被置為1時,cpu進入單步執行方式,即每執行一條指令,產生乙個單步中斷請求。這種方式主要用於程式的除錯。

指令系統中沒有專門的指令來改變標誌位tf的值,但程式設計師可用其它辦法來改變其值。

中斷允許標誌if是用來決定cpu是否響應cpu外部的可遮蔽中斷發出的中斷請求。但不管該標誌為何值,cpu都必須響應cpu外部的不可遮蔽中斷所發出的中斷請求,以及cpu內部產生的中斷請求。具體規定如下:

(1)、當if=1時,cpu可以響應cpu外部的可遮蔽中斷發出的中斷請求;

(2)、當if=0時,cpu不響應cpu外部的可遮蔽中斷發出的中斷請求。

cpu的指令系統中也有專門的指令來改變標誌位if的值。

方向標誌df用來決定在串操作指令執行時有關指標暫存器發生調整的方向。具體規定在第5.2.11節——字串操作指令——中給出。在微機的指令系統中,還提供了專門的指令來改變標誌位df的值。

i/o特權標誌用兩位二進位制位來表示,也稱為i/o特權級字段。該欄位指定了要求執行i/o指令的特權級。如果當前的特權級別在數值上小於等於iopl的值,那麼,該i/o指令可執行,否則將發生乙個保護異常。

巢狀任務標誌nt用來控制中斷返回指令iret的執行。具體規定如下:

(1)、當nt=0,用堆疊中儲存的值恢復eflags、cs和eip,執行常規的中斷返回操作;

(2)、當nt=1,通過任務轉換實現中斷返回。

重啟動標誌rf用來控制是否接受除錯故障。規定:rf=0時,表示「接受」除錯故障,否則拒絕之。在成功執行完一條指令後,處理機把rf置為0,當接受到乙個非除錯故障時,處理機就把它置為1。

如果該標誌的值為1,則表示處理機處於虛擬的8086方式下的工作狀態,否則,處理機處於一般保護方式下的工作狀態。

各種標誌位的含義

進製標誌cf主要用來反映運算是否產生進製或借位。如果運算結果的最高位產生了乙個進製或借位,那麼,其值為1,否則其值為0。使用該標誌位的情況有 多字 位元組 數的加減運算,無符號數的大小比較運算,移位操作,字 位元組 之間移位,專門改變cf值的指令等。奇偶標誌pf用於反映運算結果中 1 的個數的奇偶性...

組合語言各「標誌位」含義

1 進製標誌cf carry flag 進製標誌cf主要用來反映運算是否產生進製或借位。如果運算結果的最高位產生了乙個進製或借位,那麼,其值為1,否則其值為0。使用該標誌位的情況有 多字 位元組 數的加減運算,無符號數的大小比較運算,移位操作,字 位元組 之間移位,專門改變cf值的指令等。2 奇偶標...

標誌位的位運算應用

今天設計新版標誌位,老郭提出了乙個新的方案。以往都是乙個字段設定乙個狀態,tinyint型別,0或者1,但是這樣的壞處是如果乙個資訊表有很多狀態,需要增加很多的字段,空間利用不好,所以他提出用二進位制位運算來解決標示位的問題。設定標示位字段位tinyint型別,也就是最大128,換成二進位制就是有8...