在装配中打印Prime数字

时间:2014-09-19 03:24:04

标签: assembly printing x86 primes

我正在尝试在装配中打印1-100的素数,但不仅是我的代码打印出额外的数字,而且还排除了一些素数。

这是我的主要程序:

mov min, 1

loopStart:
  inc min                    ; min++
  mov eax, min
  cmp eax, max               ; compare 2 and 100
  je  next                   ; jump unless 2 < 100

  call isPrime               ; check if prime
  cmp ecx, 0
  jne loopStart 
push eax
  call printPrime            ; print the prime numbers
pop eax
  jmp loopStart

  next:                      ; once max is 100

  push 0                          
  call ExitProcess

我的isPrime是:

mov prime, 0                 ; set as true
mov ecx, prime                  
mov k, 2                     ; reset k 

mov edx, 0                   ; clear edx
div num                      ; n/2
mov edx, 0                   ; clear edx again

start:
cmp ecx, 0                   ; while prime
jne E                        ; if prime isnt true

cmp eax, k                   ; k<=n/2
jl E

mov eax, min
div k
cmp edx, 0                   ; check for remainder
jne kAdd

mov prime, 1                 ; set as false
jmp E

kAdd:
inc k
jmp start

E:
mov ecx, prime
mov eax, min

ret
isPrime endp

打印出:2 3 5 7 13 15 19 21 25 31 33 37 39 43 49 51 55 57 61 63 67 73 75 79 81 85 91 93 97 99

大多数额外数字是否可被3,5和7整数(都是素数)与某事有什么关系?

2 个答案:

答案 0 :(得分:1)

您未在EDX的循环内正确重置isPrime。也就是说,在div k之前,您需要设置mov edx,0xor edx,edx

另外,我不确定num在函数开头的div num中来自何处(?)。评论说您要除以2,那么您的意思是div k吗?

你的程序中有一些不必要的代码。像这样检查:

cmp ecx, 0                   ; while prime
jne E                        ; if prime isnt true

如果你看一下代码的其余部分,应该清楚ECX在这一点上永远不会有任何其他值而不是零。

答案 1 :(得分:0)

在k = k + 1

处增加k时,您忘记清除edx