已解决
汇编语言课程设计1 代码 优化版
来自网友在路上 171871提问 提问时间:2023-09-24 04:46:17阅读次数: 71
最佳答案 问答题库718位专家为你答疑解惑
assume cs:codesgstacksg segmentdw 16 dup(0)
stacksg endsdatasg segmentdb '1975','1976','1977','1978','1979','1980','1981','1982','1983'db '1984','1985','1986','1987','1988','1989','1990','1991','1992'db '1993','1994','1995';以上是表示21年的21个字符串dd 16,22,382,1356,2390,8000,16000,24286,50065,97479,140417,197514dd 345980,590827,803530,1183000,1843000,2759000,3753000,4649000,5937000;以上是表示21年公司总收入的21个dword型数据dw 3,7,9,13,28,38,130,220,476,778,1001,1442,2258,2793,4037,5635,8226dw 11542,14430,15257,17800;以上是表示21年公司雇员人数的21个word型数据
datasg endsdatasg2 segmentdb 32 dup (0)
datasg2 endscodesg segmentstart: mov ax,datasg ;原始数据mov es,axmov di,0mov ax,stacksg ;初始化栈mov ss,axmov sp,32mov ax,datasg2 ;显示字符mov ds,axmov si,0mov bl,5 ;设置行号mov cx,21 ;循环次数s: push cxmov ax,es:[di] ;低2个字节mov [si],axmov ax,es:[di+2] ;高2个字节mov [si+2],axmov word ptr [si+4],0 ;设置0结尾mov dh,blmov dl,3mov cl,2call show_str ;4个字节年份mov ax,es:[di+84] ;低2个字节mov dx,es:[di+86] ;高2个字节call dtocmov dh,blmov dl,23mov cl,4call show_str;4个字节收入mov ax,es:[si+168]mov dx,0call dtocmov dh,blmov dl,43mov cl,8call show_str ;2个字节雇员数mov ax,es:[di+84] ;低16位mov dx,es:[di+86] ;高16位;被除数div word ptr es:[si+168];除数;结果商存在ax中 mov dx,0call dtoc mov dh,blmov dl,63mov cl,2call show_str;2字节人均收入add di,4add si,2inc blpop cxloop smov ax,4c00hint 21h ;名称:dtoc;功能:将word型数据转变为表示十进制的字符串,字符串以0结尾符;参数:(ax)=dword型数据的低16位,(dx)=dword型数据的高16位; ds:si指向字符串的首地址;返回:无dtoc: push axpush bxpush cxpush dxpush sipush dsmov bx,0 ;用计数dtoc_s: mov cx,10call divdw ;返回:(dx)=结果的高16位,(ax)=结果的低16位;(cx)=余数add cx,30h ;转换为对于的ascii码push cx ;余数入栈inc bxmov cx,dx ;判断结果的高16位是否为0jcxz dtoc_s0 jmp short dtoc_s ;不为零继续进行除法运算dtoc_s0:mov cx,ax ;判断结果的低16位是否为0jcxz dtoc_s1 jmp short dtoc_s ;不为零继续进行除法运算dtoc_s1: mov cx,bxdtoc_s2:pop axmov [si],alinc siloop dtoc_s2mov ax,0mov [si],ax ;最后加个0作为结尾pop dspop sipop dxpop cxpop bxpop axret ;名称:show_str;功能:在指定的位置,用指定的颜色,显示一个用0结束的字符串;参数:(dh)=行号(取值范围1~25),(dl)=列号(取值范围1-80),; (cl)=颜色,ds:si指向字符串的首地址;返回:无show_str: push axpush bxpush cxpush dx push espush dipush dspush simov ax,0b800hmov es,axsub dh,1mov al,dhmov ah,160mul ahmov bx,ax ;bx=((dh)-1)*160sub dl,1mov al,dlmov ah,2mul ahadd bx,ax ;bx=((dh)-1)*160+((dl)-1)*2mov di,bx ;计算出的显示的位置mov al,cl ;al=cl 要设置显示的颜色show_str_s: mov cl,[si]mov ch,0jcxz show_str_ok ;判断读取的字符是否为0,等于0结束,不等于0显示当前字符mov ah,[si]mov es:[bx],ah ;设置显示的字符mov es:[bx+1],al ;设置显示的颜色inc si ;读取下一个字符add bx,2 ;指向下一个字符显示的位置jmp short show_str_sshow_str_ok: pop sipop dspop dipop espop dxpop cxpop bxpop axret;名称:divdw;功能:进行不会产生溢出的出发运算,被除数为dword型,除数为word型,结果为dword;参数:(ax)=dword型数据的低16位; (dx)=dword型数据的高16位; (cx)=除数;返回:(dx)=结果的高16位,(ax)=结果的低16位; (cx)=余数divdw: push bxmov bx,ax ;bx=Lmov ax,dx ;ax=Hmov dx,0 ;dx=0作为高16位div cxpush ax ;int(H/N)*65536入栈mov ax,bx ;ax=L;dx 余数作为高16位div cxmov cx,dx ;余数pop dx ;结果的高16位pop bxret
codesg ends
end start
查看全文
99%的人还看了
相似问题
- JVM:字节码文件,类的生命周期,类加载器
- 网工内推 | 字节原厂,正式编,网络工程师,最高30K*15薪
- Go 以小端字节序修改文件
- UDP端口接收到的字节流如何转为QJsonObject、QJsonArray的方法
- 《2020年最新面经》—字节跳动Java社招面试题
- 计算Qt中的QAudioOutput缓冲区未播放的音频字节数对应时长
- 字节面试:请说一下DDD的流程,用电商系统为场景
- 深入理解JVM虚拟机第二十一篇:详解JVM当中的操作数在栈以及分析操作数栈与字节码指令和执行引擎的关系图解
- 【Linux网络编程_TCP/UDP_字节序_套接字 实现: FTP 项目_局域网聊天项目 (已开源) 】.md updata:23/11/05
- 【项目源码】反编译Java字节码生成源码
猜你感兴趣
版权申明
本文"汇编语言课程设计1 代码 优化版":http://eshow365.cn/6-12534-0.html 内容来自互联网,请自行判断内容的正确性。如有侵权请联系我们,立即删除!