一段很简单的汇编程序!请人帮我注释哈!越详细越好哈 。

一段很简单的汇编程序!请人帮我注释哈!越详细越好哈 。,第1张

楼主,你这个也没有实质性的程序啊!除了数据段的定义,就是堆栈段的定义,没什么好注释的。若非要注释,只能把这两个段给你区分开,别的真就没什么可注释的了。

stack segment para stack 'stack' ;定义堆栈段

db 256 dup(0) ;用db不正确,应该用dw,堆栈段都是自数据

top label word ;top堆栈指针

stack ends

data segment para public 'data' ;定义数据段

;中间这些都是定义的一些数据

data ends

code segment ;定义代码段

assume cs:code,ds:data,es:data,ss:stack ;段寄存器说明

start: ;代码段开始

mov ax,data

mov ds,ax

mov es,ax

mov ah,4ch ;dos功能调用4ch号功能,结束程序,返回 *** 作系统

int 21h ;dos功能调用

code ends ;代码段结束

end start ;编译结束伪指令

data segment

msg db 'hello world$' ;定义要显示的字符串,msg为字符串名

data ends ;segment和ends成对使用,把源程序分成段,此处为数据段

;data为段名

code segment

assume ds:data, cs:code ;assume为伪指令,ds、cs为段寄存器名

_start: ;程序开始

mov ax,data ;数据段首地址送ds

mov ds, ax

lea dx, msg ;要显示的字符串首地址送dx

mov ah, 09h ;9号调用,显示输出字符串

int 21h

mov ah, 4ch ;4c号调用,程序返回DOS

int 21h

code ends ;源程序分段,为代码段,code为段名

end _start ;结束_start

最好结果:hello world

希望对你有帮助,汇编要慢慢来,刚开始可能觉得啥都不懂,到后面了就知道了

你等我

DATANUM=10 ;设有10个数据

STACK SEGMENMT STACK ‘STACK’

DW 100H DUP()

TOP LABEL WORD

STACK ENDS

DATA SEGMENT

DATABUF DW DATANUM

DB DATANUM DUP(?)

DATA EDATANUMDS

CODE SEGMENT

ASSUME CS:CODE,DS:DATA,ES:DATA,SS:STACK

START:

MOV AX,DATA

MOV DS,AX

MOV ES,AX

MOV AX,STACK

MOV SS,AX

LEA SP,TOP

; 取出随机数据

MOV CX,DATABUF

LEA SI,DATABUF+2

MOV BL,23

MOV AL,11

LP:

MOV [SI],AL

INC SI

ADD AL,BL

LOOP LP

; 数据排序

MOV CX,DATABUF

DEC CX

LEA SI,DATABUF+2

ADD SI,CX

LP1:

PUSH CX

PUSH SI

LP2:

MOV AL,[SI]

CMP AL,[SI-1]

JAE NOXCHG

XCHG AL,[SI-1]

MOV [SI],AL

NOXCHG:

DEC SI

LOOP LP2

POP SI

POP CX

LOOP LP1

;数据排序结束

MOV AH,4CH ;返回DOS

MOV AL,0

IDATANUMT 21H

CODE ENDS

END START

我这个连中断都用上了

第二题

PUSH PSW ;保护现场

PUSH A

CLR C ;进位标志位清零

MOV DATA,DATA2

MOV A,DATA1

SUBB A,DATA ;求Yn-1 -Yn

JNC COMPARE ;如果Yn-1 -Yn≥0,转COMPARE

CPL A ;如果Yn-1 -Yn<0, 求补

INC A

COMPARE: CLR C

SUBB A,LIMIT ;│Yn-Yn-1│和△y比较

JC OVER ;如果│Yn-Yn-1│≤△y,DATA2→DATA

MOV DATA,DATA1 ;如果│Yn-Yn-1│>△y,DATA1→DATA

OVER: POP A ;恢复现场

POP PSW

RET ;返回

这个作为参考,是MCS的

;入口 :A,SDAT,DELTY

;占用资源:B

;堆栈需求:2字节

;出口 :A

JUGFILT :MOV B,A

CLR C

SUBB A,SDAT

JNC JUGFT1

CPL A

INC A

JUGFT1 :SETB A

SUBB A,#DELTY

JNC JUGFT3

MOV A,SDAT

RET

JUGFT3 :MOV A,B

MOV SDAT,A

RET

;中位值滤波程序

;入口 :ADDPH,ADDPL,N

;占用资源:ESELSORT

;堆栈需求:4字节

;出口 :A

MEDFILT :LCALL ESELSORT

MOV A,N

CLR C

RRC A

ADD A,ADDPL

MOV DPL,A

MOV A,ADDPH

MOV DPH,A

JNC MEDFT1

INC DPH

MEDFT1 :MOVX A,@DPTR

RET

;N点算术平均滤波

;入口 :ADDPH,ADDPL,N

;占用资源:B,R3,R4

;堆栈需求:2字节

;出口 :A

AVFILT :MOV A,ADDPL

MOV DPL,A

MOV A,ADDPH

MOV DPH,A

CLR A

MOV R3,A

MOV R4,A

MOV R7,N

AVFT1 :MOVX A,@DPTR

INC DPTR

ADD A,R4

MOV R4,A

JNC AVFT2

INC R3

AVFT2 :DJNZ R7,AVFT1

MOV R7,N

MOV R2,#00H

LCALL NDIV31

MOV A,R4

RET

;N点加权平均滤波

;入口 :ADDPH,ADDPL,N

;占用资源:B,R3,R4

;堆栈需求:2字节

;出口 :A

QAVFILT :CLR A

MOV R3,A

MOV R4,A

MOV R7,N

MOV P2,ADDPH

MOV R1,ADDPL

MOV DPTR,#QAVTAB

QAVFT1 :MOVC A,@A+DPTR

MOV B,A

MOVX A,@R1

INC DPTR

INC R1

MUL AB

ADD A,R4

MOV R4,A

MOV A,B

ADDC A,R3

MOV R3,A

DJNZ R7,QAVFT1

MOV A,R4

JNB ACC7,QAVFT2

INC R3

QAVFT2 :MOV A,R3

RET

QAVTAB :DB

;一阶加权滞后滤波程序

;入口 :A,DELTY

;占用资源:B,R3,R4

;堆栈需求:2字节

;出口 :A

BQFILT :MOV B,A

CLR A

MOV DPTR,#ABTAB

MOVC A,A+DPTR

MUL AB

MOV R4,A

MOV R3,B

MOV A,01H

MOVC A,A+DPTR

MOV B,DELTY

MUL AB

ADD A,R4

MOV R4,A

MOV A,B

ADDC A,R3

MOV R3,A

MOV A,R4

JNB ACC7,FT1

INC R3

FT1 :MOV A,R3

MOV DELTY,A

RET

BQTAB :DB 80H,80H

将汇编语言编写的程序转换为目标程序。

汇编语言是为特定计算机或计算机系列设计的一种面向机器的语言,由汇编执行指令和汇编伪指令组成。采用汇编语言编写程序虽不如高级程序设计语言简便、直观,但是汇编出的目标程序占用内存较少、运行效率较高,且能直接引用计算机的各种设备资源。

它通常用于编写系统的核心部分程序,或编写需要耗费大量运行时间和实时性要求较高的程序段。

扩展资料

简单汇编程序

简单汇编程序又称“装入并执行”式汇编程序。由于简便而得到广泛使用。这种汇编程序的特点是汇编后的机器语言程序直接放在内存之中准备执行。

 目标程序所占据的存储位置是在汇编时固定的,并且以后不能改变,所以这种工作方式不能将多个独立汇编的子程序合并为一个完整的程序,而且只能调用位置与目标程序不冲突的程序库中的子程序。

;

ORG 0000H

AJMP START

ORG 0100H

START:

MOV 42H, #88H ;先设NA<NB

MOV A, 40H

CJNE A, 50H, LOOP1 ;NAH-NBH

SJMP NEXT ;相等则再去比较低八位

LOOP1:

JC LOOP ;不够减,就可以结束了

AJMP LOOP3 ;转

NEXT:

MOV A, 41H

CJNE A, 51H, LOOP2 ;NAL-NBL

LOOP2:

JC LOOP ;不够减,就可以结束了

LOOP3:

MOV 42H, #0FFH ;否则就是NA>=NB

LOOP:

AJMP LOOP

END

; 本程序通过编译,运行正确

Code Segment

Assume CS:Code,DS:Code

W dw 378

X dw 456

Z dw 269

Start: push cs

pop ds ;使数据段与代码段同段

mov ax,X

sub Z,ax ;Z-X→Z

mov ax,W

add Z,ax

Exit_Proc: mov ah,4ch ;结束程序

int 21h

Code ENDS

END Start ;编译到此结束

要注意的是,通常堆栈段中不定数据,而是用来做堆栈。

X_SEG segment

X DW

X_SEG ends

Y_SEG

Y DW

Y_SEG ends

Z_SEG

Z DW

Z_SEG ends

X_SEG segment

assume ds:X_SEG,es:Y_SEG,ss:Z_SEG

start :

push ds

xor ax,ax

push ax

mov ax,Z_SEG

mov ss,ax

mov ax,X_SEG

mov ds,ax

mov ax,Y_SEG

mov es,ax

mov ax,X

add ax,es:Y

add ax,ss:Z

mov X,ax

X_SEG ends

end start

end

以上就是关于一段很简单的汇编程序!请人帮我注释哈!越详细越好哈 。全部的内容,包括:一段很简单的汇编程序!请人帮我注释哈!越详细越好哈 。、谁能帮我把这个简单的汇编程序注释一下啊!本人刚入门!不懂啊!、新手求教汇编语言程序,超级简单,但是我就是不会写,头疼死了等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

原文地址:https://54852.com/zz/9331960.html

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

发表评论

登录后才能评论

评论列表(0条)

    保存