彙編中段的使用

段與段不能重合使用!!!

下面這種做法很不安全,如果在程序中出現這種程序代碼,將CS段地址直接賦值給SS段使用,有可能導致災難性後果。因爲在段初始化時,會將幾個寄存器值放到段內,隨着PUSH操作的進行,這些值將會向低地址方向作整體移動,此時會覆蓋CS段內開始定義的8個字的數據。

assume cs:codesg

codesg segment
	dw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987h
	dw 0,0,0,0,0,0,0,0
start:	mov ax,cs
	mov ss,ax            #將CS段地址直接賦給SS段
	mov sp,30h
		
	mov bx,0
	mov cx,8
s:	push cs:[bx]
	add bx,2
	loop s
		
	mov bx,0
	mov cx,8
s0:	pop cs:[bx]
	add bx,2
	loop s0
		
	mov ax,4c00h
	int 21h
		
codesg ends
end start

程序運行前,內存狀態:

第1次push操作後,內存狀態:

第3次push操作後,內存狀態:

push操作結束後,內存狀態:

可以看到,在push操作的後期,對原始定義的數據進行了覆蓋或者修改,導致最後脫離了控制。

所以,在一個程序中若使用多個段,應對多個段進行單獨定義。如下代碼。獨立定義使用段空間後,進行PUSH/POP操作也不會影響其它段內的數據。

assume cs:code

a segment
	dw 1,2,3,4,5,6,7,8,9,0ah,0bh,0ch,0ch,0eh,0fh,0ffh
a ends

b segment                            #多個段獨立定義使用
	dw 0,0,0,0,0,0,0,0
b ends

code segment
start:	mov ax,a
	mov ds,ax
		
	mov ax,b
	mov ss,ax
	mov sp,16
	
	mov bx,0
	mov cx,8
s:	push ds:[bx]
	add bx,2
	loop s
		
	mov ax,4c00h
	int 21h

code ends
end start

程序運行前,內存狀態:

第1次push操作後,內存狀態:

第4次push操作後,內存狀態:

push操作結束後,內存狀態:

由此可見,對多個段進行獨立定義使用,可以很好地保護相鄰的內存數據。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章