《汇编语言》王爽 实验7

该博客介绍了两种方法在汇编语言中将数据从一段内存区域转移到另一段,并进行求平均值的计算。第一种方法按种类写入,分别处理年份、总收入和雇员人数;第二种方法按行写入,一次性处理所有数据。博客展示了如何使用寄存器和栈进行操作,以及如何进行除法运算。

《汇编语言》王爽 实验7

自己想的,比较弱智的方法,供大家一笑

方法1:
按种类写入

assume cs:code, ds:data, ss:table

data segment
         db '1975','1976','1977','1978'
         dd 16,22,382,1356
         dw 3,7,9,13
data ends

table segment
          db 4 dup ('year summ ne ?? ')
table ends

code segment
start:    mov  ax,data
          mov  ds,ax
          mov  ax,table
          mov  ss,ax
         
          mov  bx,0 ;ds列
          mov  si,0 ;ds行
          mov  bp,0 ;ss列
          mov  di,0 ;ss行
          mov  cx,4 ;循环次数

    s:    
          mov  ax,ds:[bx+si]  ;年份
          mov  ss:[bp+di],ax
          mov  ax,ds:[bx+si+2]
          mov  ss:[bp+di+2],ax
          add  bx,4
          add  di,16
          loop s

          mov  bx,0 ;ds列
          mov  si,16 ;ds行
          mov  bp,5 ;ss列
          mov  di,0 ;ss行
          mov  cx,4 ;循环次数

    s0:   mov  ax,ds:[bx+si]  ;总收入
          mov  ss:[bp+di],ax
          mov  ax,ds:[bx+si+2]
          mov  ss:[bp+di+2],ax
          add  bx,4
          add  di,16
          loop s0

          mov  bx,0 ;ds列
          mov  si,32 ;ds行
          mov  bp,10 ;ss列
          mov  di,0 ;ss行
          mov  cx,4 ;循环次数

    s1:   mov  ax,ds:[bx+si]  ;雇员人数
          mov  ss:[bp+di],ax
          add  bx,2
          add  di,16
          loop s1

          
          mov  bp,5 ;ss列
          mov  di,0 ;ss行
          mov  cx,4 ;循环次数

    s2:   mov  ax,ss:[bp+di]
          mov  dx,ss:[bp+di+2]
          mov  bx,ss:[bp+di+5]
          div  word ptr bx
          mov  ss:[bp+di+8],ax
          add  di,16
          loop s2

          mov  ax,4c00h
          int  21h

code ends

end start






       

方法2:
按行写入

assume cs:codesg,ds:datasg

datasg segment
    db '1975','1976','1977','1978','1979','1980','1981','1982','1983'
	db '1984','1985','1986','1987','1988','1989','1990','1991','1992'
	db '1993','1994','1995'
    ;年份:4*21=84byte,00h-53h

    dd 16,22,382,1356,2390,8000,16000,24486,50065,97479,140417,197514
	dd 345980,590827,803530,1183000,1843000,2759000,3753000,4649000,5937000
    ;收入:4*21=84byte,54h-a7h

    dw 3,7,9,13,28,38,130,220,476,778,1001,1442,2258,2793,4037,5635,8226
	dw 11542,14430,15257,17800
    ;人数:2*21=42byte,a8h-d1h
datasg ends

table segment
    db 21 dup('year summ ne ?? ')
table ends

codesg segment
start:  mov ax,datasg
        mov ds,ax
        mov ax,table
        mov es,ax

        mov bx,0 ;ds列
        mov si,0 ;ds行
        mov bp,0 ;es列
        mov di,0 ;es行
        mov cx,21
        
    s:  mov ax,ds:[bx+si+0]          ;年份
        mov es:[bp+di+0],ax
        mov ax,ds:[bx+si+2]
        mov es:[bp+di+2],ax
        add si,84
        add bp,5
        mov ax,ds:[bx+si+0]          ;收入
        mov es:[bp+di+0],ax
        mov ax,ds:[bx+si+2]
        mov es:[bp+di+2],ax
        add si,84
        add bp,5
        mov ax,ds:[bx+si+0]          ;人数
        mov es:[bp+di+0],ax
        add di,16
        add bx,4
        mov si,0
        mov bp,0
        loop s

        mov bp,6                     ;计算
        mov di,0
        mov cx,21

    s1: mov ax,es:[bp+di]
        mov dx,es:[bp+di+2]
        mov bx,es:[bp+di+6]
        div word ptr bx
        mov es:[bp+di+7],ax
        add di,16
        loop s1


        mov ax,4c00h
        int 21h
codesg ends

end start

        





        

很多数据自己简化了,开始纠结寄存器不够用,所以栈寄存器也用了,看了别人答案发现是自己脑子不够用

### 关于王爽汇编语言实验教程的概述 #### 子程序设计的核心概念 子程序的设计在汇编语言中是一个重要的主题,通过 `CALL` 和 `RET` 指令来实现函数调用和返回的功能。这些指令不仅修改了指令指针(IP),还可能涉及代码段寄存器(CS)的变化[^2]。合理使用栈结构保存寄存器的状态是确保子程序执行前后环境一致的关键之一[^4]。 以下是基于上述描述的一个简单子程序示例: ```asm ; 定义数据段 DATA SEGMENT IDATA DB 10H, 20H ; 初始化的数据 DATA ENDS ; 定义代码段 CODE SEGMENT ASSUME CS:CODE, DS:DATA START: MOV AX, DATA ; 设置数据段地址到AX MOV DS, AX ; 将AX中的值传给DS LEA BX, IDATA ; 加载IDATA的有效地址到BX CALL SUB_PROC ; 调用子程序SUB_PROC MOV AH, 4CH ; 准备退出程序 INT 21H ; 中断请求 SUB_PROC PROC ; 子程序定义 PUSH AX ; 保护AX寄存器 MOV AL, [BX] ; 取第一个字节到AL INC BX ; 增加BX指向下一个字节 MOV AH, [BX] ; 取第二个字节到AH POP AX ; 恢复AX寄存器 RET ; 返回调用处 SUB_PROC ENDP CODE ENDS END START ; 结束程序 ``` 此代码展示了如何通过 `[BX+idata]` 的方访问内存中的数据,并且演示了子程序的基本框架以及栈操作的重要性。 #### 显存与内存布局的理解 对于显存或更广泛的内存管理而言,在实际应用中需要注意其线性存储特性。尽管屏幕呈现时存在行列的概念,但从硬件角度看并没有真正的“行”的划分。例如,当处理字符模下的视频缓冲区时,通常会按照每两个字节表示一个字符及其属性的方来组织数据[^5]。 #### 溢出标志的应用场景 溢出标志位 (OF) 主要用于检测带符号整数算术运算过程中是否存在超出目标范围的情况[^3]。这在编写健壮性的软件组件时尤为重要,尤其是在金融计算或其他对精度敏感领域内的算法开发阶段。 --- ###
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值