在微机上运行某个程序时,如果存储容量不够,解决的办法是

在微机上运行某个程序时,如果存储容量不够,解决的办法是,第1张

扩充内存

微机运行某个程序时,直接与CPU打交道的是内存,与外存是没有关系的,所以在微机上运行某个程序时,如果存储容量不够时需要扩充内存。

电脑添加内存首先必须了解以下三个方面的基本情况:

电脑系统及主板所能支持的最大内存容量;主板上内存插槽的剩余数量;电脑已安装内存的规格。

了解电脑系统及主板所能支持的最大内存容量,最大支持内存和 *** 作系统有直接关系,即使是64位处理器,如果使用32位 *** 作系统,支持的内存最多为2的32次方,即4GB。所以在windows32位 *** 作系统中最大只能识别3.25-3.75GB之间,根据windows版本不同有差异。

64位 *** 作系统的寻址能力为2的64次方,即17179869184GB,但这只是理论值,实际不可能用到这么大的内存,目前64位windows系统最大只能支持128GB内存。

扩展资料:

扩充内存需要注意注意,Win32位的系统,最高支持3.25G左右的内存,无论主板最高支持多大,但32位系统最高只能支持3.25G左右内存。

如果电脑安装的内存为4G或4G以上,则应安装64位的 *** 作系统,以获得更大的内存支持,加快PC的处理速度,电脑支持的最大内存=硬件+ *** 作系统。

使用扩充内存必须在计算机中安装专门的扩充内存板,而且还要安装管理扩充内存板的管理程序。由于扩充内存是在扩展内存之前推出的,所以大多数程序都被设计成能使用扩充内存,而不能使用扩展内存。

参考资料:

百度百科-扩充内存

MOV DX,0F100H DX=0F100H

MOV DH,[DX] DH=(0F100H)='A'=41H DX=4100H 取内存0f100h处存放的字符'A'存入DH,'A'的ASCII码为41H,DH为DX寄存器高位,所以DX发生变化

MOV AH,[DX] AH=(04100H)='B'=42H 原理同上

所以正确的是AH中存放的是42H,不是41H,另外DX寄存器不能作为间接寻址寄存器,可以使用BX寄存器代替。

BUFFER DB 10 DUP();BUFFER存放8个不确定数

augend DB 2 DUP() ;加数

addend DB 2 DUP() ;加数

msg1 DB 0DH,0AH,'请输入被加数: $'

msg2 DB 0DH,0AH,'请输入加数: $'

msg3 DB 0DH,0AH,'结果: $';msg3存放结果

;0DH和0AH分别是回车和换行的ASCII码,

;'$'是DOS功能调用INT 21H中9号功能要求的要显示字符串的结束标志

CODE

START: MOV AX,@DATA

MOV DS,AX

MOV ES,AX

CLD ;方向标志位清零 ;CLD与STD是用来 *** 作方向标志位DF(Direction Flag)。

;CLD使DF复位,即DF=0,STD使DF置位,即DF=1用于串 *** 作指令中

NOP ;空 *** 作 ;NOP指令只使程序计数器PC加1,所以占用一个机器周期

;其目的为保证写、读之间有个稳定时间

MOV AH,00H

MOV AL,03H

INT 10H ;清屏

START1: MOV AH,09H ;9号调用DX指向被加数的首地址,输出提示信息

LEA DX,msg1 ;将源 *** 作数给出的有效地址传送到指定的的寄存器中

INT 21H

LEA DI,augend ;DI->augend的首地址

MOV CX,4 ;按键次数

CALL GetBCDKey ;得到双字节十进制数(被加数)

JNB START2 ;没有输入任何数字,结束 CF=0

MOV AH,09H ;9号调用DX指向加数的首地址

LEA DX,msg2 ;将源 *** 作数给出的有效地址传送到指定的的寄存器中

INT 21H

LEA DI,addend ;di指向加数

MOV CX,4 ;按键次数

CALL GetBCDKey ;得到双字节十进制数(加数)

JNB START2 ;没有输入任何数字,结束

MOV AL,augend ;被加数的低8位送al

ADD AL,addend ;al与加数的低位相加的结果送al

DAA ;BCD算术运算调整,转换为压缩型BCD

XCHG AL,AH ;高位与低位互换

MOV AL,augend + 1

ADC AL,addend + 1 ;高位

DAA

XCHG AL,AH

MOV BL,0

ADC BL,0 ;进位 bl存放的是进位 bl和ax相加是最后的结果

STD ;方向标志置1

LEA DI,BUFFER+4 ;存放显示结果

CALL B1toB2 ;低位

MOV AL,AH

CALL B1toB2 ;高位

MOV AL,BL

OR AL,30H ;转换成数字

STOSB ;存数

LEA SI,BUFFER

MOV CX,5

CALL BlackDisplay ;将高位0消隐

MOV AH,09H

LEA DX,msg3 ;9号调用DX指向结果的首地址

INT 21H

MOV AH,09H

LEA DX,BUFFER ;9号调用DX指向BUFFER的首地址

INT 21H

JMP START1 ;跳转到START1

START2: MOV AH,4CH ;结束程序

INT 21H

; JMP $

;将一个字节压缩BCD码转换成二个字节数字

B1toB2 PROC NEAR ;段内

PUSH AX ;ax存放的是相加后的结果

AND AL,0FH ;高四位置0

OR AL,30H ;加30H

STOSB ;存数 个位 百位

POP AX

AND AL,0F0H ;低四位置0

ROR AL,4 ;循环右移4位

OR AL,30H ;加30H

STOSB ;存数 十位 千位

RET

B1toB2 ENDP

BlackDisplay PROC NEAR

CLD ;方向标志清零

MOV DI,SI ;si送给di si指向buff的第一个缓冲区 增量变化

BlackDisplay1: LODSB ;将高位0消隐,取串

CMP AL,'0'

JNZ Exit ;若al不等于0跳转EXIT

LOOP BlackDisplay1 ;否则cx不为0一直循环 cx次

INC CX ;cx加1

Exit: DEC SI ;si前移

REP MOVSB ;重复传送字节

MOV AL,'$' ;把$符送al

STOSB ;存数

RET

BlackDisplay ENDP

GetBCDKey PROC NEAR

LEA SI,BUFFER

MOV AL,4 ;把4写入到buff

MOV [SI],AL ;是内存单元

MOV DX,SI

MOV AH,0AH ;dx指向缓冲区

MOV AL,02H ;0:任意字符 1:16进制数 2:10进制数,10进制数输入

INT 21H

GetBCDKey1: LODSB ;ds:si->al

AND AL,0FH ;高4位清零

CMP CX,1 ;

JE GetBCDKey2

DEC CX ;进数位-1

MOV AH,AL

LODSB

AND AL,0FH

SHL AL,4 ;逻辑左移4位

OR AL,AH ;

GetBCDKey2: CLD

STOSB ;存串指令

STD

LOOP GetBCDKey1 ;cx=2 原先为4 上面减了一次一 loop再减一所以等于2

MOV CL,[BUFFER]

SUB CL,[BUFFER+1]

SHR CL,1 ;逻辑右移1位

MOV AL,0

CLD

REP STOSB ;重复存数

STC ;进位标志位置1

RET

GetBCDKey3: CLC ;进位标志位清零cf=0

RET ;返回

GetBCDKey ENDP

;输入被加数

mov ah,1

int 21h

mov bl,al

;输入加数

mov ah,1

int 21h

;输出求和表达式

mov dl,bl

mov ah,2

int 21h

mov dl,'+'

int 21h

mov dl,al

int 21h

mov dl,'='

int 21h

;求和

and bl,0fh

and al,0fh

add al,bl

daa

;输出结果高位

mov dl,al

mov cl,4

shr dl,cl

or dl,30H

mov ah,2

int 21h

;输出结果低位

mov dl,al

and dl,0fh

or dl,30H

mov ah,2

int 21h

以上就是关于在微机上运行某个程序时,如果存储容量不够,解决的办法是全部的内容,包括:在微机上运行某个程序时,如果存储容量不够,解决的办法是、简单的微机原理程序运行结果、合肥学院微机实验4(子程序调用实验代码及解析)等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/10631902.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-10
下一篇 2023-05-10

发表评论

登录后才能评论

评论列表(0条)

保存