十、实模式和保护模式简介

1.   纯DOS的实模式:

       a. 背景是DOS特别简单,没有能力对硬件系统进行全面、严格地管理,因此对用户的一些非法操作将不会检查到,从而这些非法操作可能会导致系统崩溃;

       b. 因此在DOS系统中用户可以毫无顾虑地对硬件进行操作,而不受到操作系统的限制;

       c. 这就是实模式;

       d. 如果在实模式下用户非法修改了DOS系统在内存中的空间可能会直接导致系统崩溃;


2.   CPU保护模式:

       a. 在8086CPU之后基本上都提供了CPU的保护模式,即可以限制用户的一些操作,而保证操作系统的安全;

       b. 对于现代操作系统比如Unix、Windows系列等都利用了CPU的保护模式,对硬件系统进行严格地管理,使得硬件系统对用户来说是屏蔽的,用户只能看到操作系统,但是不能接触到硬件系统,硬件系统(即所有的硬件资源)都被操作系统管理着;

       c. 因此在保护模式下非法访问操作系统或者其它应用程序或者是硬件在内存中的空间将会被视为非法,而被强制踢出或者终止你的行为;

       d. 因此在保护模式中想要用汇编语言去真实地操作硬件系统是完全不可能的;


3.   DOS中的安全空间:一般在DOS中0:200~0:2FF中的256个字节是空白的,可以用在Debug中用D命令查看(值都是0),因此可以放心地使用;


4.   程序示例:将FFFF:0~FFFF:B中的数据复制到0:200~0:20B中:

       可以逐个字节复制:

assume cs:codesg

codesg segment

	mov ax, 0ffffh
	mov ds, ax
	mov ax, 20h 
	mov es, ax

	mov bx, 0
	mov cx, 0ch

s:	mov al, [bx]
	mov es:[bx], al
	inc bx
	loop s

	mov ax, 4c00h
	int 21h

codesg ends

end

        注:使用两个段寄存器,并且运用段前缀访问内存的方式,可以使程序得到大大的简化,而不必使用一个段寄存器做两次中转来表示两个需要进行数据交换的段基地址了;


5.   程序示例:将0:200~0:23F中的字节单元依次赋值为0~3F:

assume cs:codesg

codesg segment

	mov ax, 20h
	mov ds, ax
	mov bx, 0      ;地址必须是16位的,因此无法使用bl等与8位数据适配,而只能用16位寄存器
	mov cx, 40h

s:	mov [bx], bl   ;此句很巧妙,由于64个数据没有超过8位,因此bx的第8位的数据仍然正确
	inc bx
	loop s

	mov ax, 4c00h
	int 21h

codesg ends

end
       使用栈的做法:

assume cs:codesg

codesg segment

	mov ax, 20h
	mov ss, ax
	mov sp, 40h
	mov ax, 3f3eh

	mov cx, 32
s:	push ax
	sub ax, 202h
	loop s

	mov ax, 4c00h
	int 21h

codesg ends

end


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值