Java教程

第一次自己写汇编,输出100以内的素数,但是一运行就卡死。

本文主要是介绍第一次自己写汇编,输出100以内的素数,但是一运行就卡死。,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

assume cs:cseg,ds:dseg
dseg segment stack
sushu dw 50h dup (?);创建一个50个字节的空数据用于放素数
dseg ends
cseg segment
start: mov ax,dseg;连接段寄存器
mov ds,ax
mov cx,100;100 个数字并循环100次
sort: push cx;入栈
mov si,0;指针归零
inner:
mov ax,cx;将cx的值给了ax
mov bx,2;从2开始除
xxun:
div bx;ax除bx并将结果商放在al余数放在ah
cmp ah,0;比较余数和0
je dxun;相等则跳出小循环
inc bx;不相等则bx自加,用于下一次的除数
mov ax,cx
mov dx,2h
div dx;将cx除以2,并与除数比较,不小于除数则进行再次循环,如果小于则说明是素数
cmp ax,bx
jae xxun

noswap:
mov [si],cx;将素数存入并再次循环
add si,2
loop inner;跳转并将cx的值减一
pop cx;出栈
jmp shuchu

dxun:
loop inner
pop cx
jmp shuchu

shuchu:
lea dx,sushu;输出素数
mov ah,09h
int 21h

mov ax,4c00h;结束程序
int 21h
cseg ends
end start

这篇关于第一次自己写汇编,输出100以内的素数,但是一运行就卡死。的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!